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A&STRACT 


Various schemes for digital processing of speech 
signals is reviewed. Those schemes employing parametric 
analysis of speech data, viz,, the vocal tract and excitation 
functions, provide for efficient coding and data rate compre- 
ssion. 

An LPC analysis/synthesis system is taken up in 
detail and its hardware implementation is suggested. This 
scheme consists of two parts; — a pitch period estimator, and 
an LPC analyzer., 

An excitation analyser needed to obtain the . pitch 
period estimates of a speech signal is implemented. This 
implementation uses; a special purpose, signal processing 
microcomputer, the Intel 2920. Signal processing functions 
such as digital Ijemer filters, peak detectors and run down 
circuits are implemented on this processor. The pitch esti- 
mates and voiced/xinvoiced decisions are made using the 
Parallel Processing method of Gold and Rabiner. An 8085 
microprocessor is tused for the final computation of the 
pitch period from parallel estimates in an interrupt service 
routine. The estimator does provide fairly acctirate results. 
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CHAPTER 1 


SPEECH PROCESSING 


1.1 INTRODUCTION 

Digital processing of speech has been an active, 
subject of study for several decades. It has acquired added 
importance with digital transmission of speech and secure 
communications. The attraction has resulted from the wide 
variety of applications from communications to automatic 
reading machines [l]. In this thesis various speech anal- 
ysis sy»tcms have been discussed briefly. In detail, is 
available the implementation of a pitch period estimator, 
which forms an important part of any speech analysis- 
synthesis system. 

1.2 SPEECH PROCESSING 

Speech processing problems fall broadly into three 
classes depending on application [3, 4 j. 

a) Speech analysis - for such applications as 

- speech recognition 

- speaker identification 

- speaker verification 

b) speech synthesis - for apprication in * 

- automatic reading machines 

- data retrieval, verbally, from a computer as when 
a data base is to be interrogated from an ordinairy 
telephone . 
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c) Analysis followed by synthesis - for voice, communication 
uses with the aim of 

- secure voice transmission 

- data rate compression of speech. 

It is this third class of problems that this work addresses 
itself to, 

1.3 rate compression of speech 

By simply sampling and digitising speech w’e have a 
rate of the order of 64 K bits/ sec. However, through the 
use of speech analysis followed by appropriate coding at the 
transmission end and resynthesis at the receiver, this can be 
reduced by a factor between 10 and 50. The reduction factor 
depends on the type of system used and 'the speech quality [3j 
desired. Intelligible speech can be communicated at as low 
as 2,5 K bits/sec. For accommodating nuances of speech such 
as inflection, tone and auditory hints to the speakers 
identity, which are desirable in human ccranunications , higher 
data rates must be used to accommodate this information. 

1.4 SPEECH PROCESSING TECHNIQUES 

' The techniques available for speech processing are 
broadly divided into two classes: 

(a) Waveform coding methods 

(b) Methods based on .the structure of speech. . 



1.4.1 Waveform Coding 


In waveform coding methods [ 2 ] the only assumption 
made is that the signal is bandlimited. This class can in 
general be applied to any bandlimited time function. These 
are the PCM, DPCM and DM techniques. If adaptive quantizers 
are incorporated in these, we have the APCM, ADPCM and ADM 
with better performance at a higher cost. Mention nay also 
be made of the LDM (linear delta modulation), CDM (continuous 
DM) and the DCDM (digitally controlled DM). In all, these 
techniques provide higher SNR at data rates of 30 to 50 
K bits/sec. The perceptual speech quality is dependent on 
the quantisation technique and the number of bits per sample. 
A study [ 2 , 4 ] show's that objective ratings, based on SNR 
considerations and sxibjective ratings based on listener 
preferences can vary, as show'n in Figure 1.1. 

Here it is evident that transmission rates betwreen 
24 to 56 K bits/sec are needed for a sample rate of 8 KHz, 
to obtain a reasonable quality of speech, 

1.4.2 Parametric Coding 

This class of techniques is tailored for the speech 
waveform in the sense that they capitalise on its structure, 
when represented by a model consisting of a slowly varying 
linear system excited by an appropriate excitation signal. 

To mention a few of the methods [l, 3, 4] in this class we 
have the Linear Predictive Coding (LPC) , Homomorphic filt- 
ering and Formant analysis. These methods are attractive 
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since they offer lower bit rates by transmitting only the 
speech parameters rather than the actual waveform itself. 
These are discussed in the next chapter. 

1.5 MODEL. OF SPEECH WAVEFORMS 

The second class of techniques for speech analysis 
and synthesis can be viewed in terms, of a model of the speech 
waveform as the response of a slowly time varying system to 
either a periodic or noise like excitation. 

a 

1.5.1 The Speech Mechanism 

The speech mechanism essentially consists of: 

(a) The vocal tract which is an acoustic tube with 
non \aniform cross sectional area, ranging from the vocal 
chord constriction at the mouth of the trachea to the lip at 
the other end. During speech the vocal tract is defomed in 
cross sectional area by movement of the articulators namely, 
the ripS/ jaw, tongue and the velum (soft jsiate). 

(b) The excitation source or, the source of energy 
for the speech production lies in the thoracic and abdominal 
musculatures. In the case of voiced speech sounds, the 
excitation corresponds to a quasi periodic pulse train, 
representing air flow through the vocal chords as they 
vibrate. The fricative sounds are generated by forcing 
a^r through a constriction in the vocal chords, creating 
txirbulence which in turn produces a source of noise to 
excite the vocal tract [l]. 



As suggested in the preceding discussion, the speech 
waveform can be modelled as the response of a linear time 
varying system, the vocal tract, with the appropriate excit- 
ation. 

Figure 1.2(a) shows that for a fixed vocal tract, 
the output of the system is the convolution of vocal tract 
and excitation impulse responses. The vocal tract changes 
for different sounds, and since this change is a slow one, 
the output can be approximated as a convolution on a short 
time basis. 

1.6 SHORT TIME ANALYSIS AND SYNTHESIS OF SPEECH 

1.6.1 Requirement of the Short Time Basis 

Figure 1.2(b) shows the model in the frequency 
domain where the speech output is a composite spectrum of 
the product of a line spectrum (Fourier transform (FT) of 
the excitation for a voiced signal) and the FT of the vocal 
tract impulse response. 

To generate different sounds, the vocal tract shape 
and hence the envelope of the output spectrum changes. 
Similarly, as the excitation period changes for voiced 
sounds, the spacing of the pitch harmonics will change. 

Since both the components of the output product 
change, albeit slowly, with time, a short time analysis is 
desirable and meaningful. 

Identically the short time basis is implied during 
synthesis for which purpose, periodic information of the 



excitation and vocal tract parameters are adequate. 

1.6,2 Duration of the "Short Time" 

A natural question to follow at this stage is how 
short or long can the "short time" be. Many y;orks in the 
area suggest that the time interval lie between 10 to 40 
msec. Instinctively more accurate representation of analysed 
speech is better obtained at smaller intervals. However, 
subjective listener tests [l , 5j indicate a wide variance 
depending upon the analysis- synthesis methods used. Once 
again desired speech quality can determine the duration of 
the "short time", along with the restrictions imposed by the 
method of ana lysis- synthesis in consideration, 

1.7 thesis outline 

The region of study is the Parametric coding methods. 
In this thesis an attempt to study the hardware implementa- 
tion of one type of Parametric coding technique is made. 

Chapter 2 introduces and reviews the various types 
of ana lysis- synthesis methods available and their implemen- 
tation in vocoders. 

Chapter 3 mentions available schemes for the 
extraction of the excitation parameter, or pitch period, at 
block diagram level. The Parallel Processing Algorithm of 
Gold and Rabiner [6 j is discussed along with the modifica- 
tion chosen for implementation. 

Chapter 4 covers in detail the hardware and software 
for the implementation of the Parallel processing pitch 
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period estimation algorithm. 

Chapter 5 contains suggestions for improvement of 
the implemented design and also a scheme for the realisation 
of a complete i,PC vocoder. 

Appendix A contains the hardware details. 

Appendix B contains printouts of software programmed 
on to the 2920 Signal Processing Chip. 

Appendix C has the printout of the 8085 program used 
for final computation of the pitch period. 

Appendix D contains notes on the. use of 2920 Signal 
Processor and Software Application Package. 
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CHAPTER 2 

REVIEW OF SPEECH ANALYSIS SYNTHESIS, SYSTEMS 

2.1 SPEECH ARAL YSIS-SYNTHESIS SYSTEMS 

To capitalise on the model of speech presented in 
Chapter 1, most analysis- synthesis methods attempt, in one 
way or another, to deconvolve the speech signal to achieve 
separation of the vocal tract characteristics from the exci- 
tation fmction. Svach systems lead to significant data rate 
compression for speech storage or transmission at the cost 
of quality. This results from the fact that the deconvol- 
ution cannot be precisely implemented [ 3 ]. Several methods 
of analysis are available for implementation in speech pro- 
cessing systems. The synthesis can then be performed in one 
of the synthesizers available. 

2 . 2 analysi s techni que s 

A variety of analysis methods are possible based on 
the output of a slowly varying linear system. Those of 
interest are 

a) Short time autocorrelation analysis [llj 

b) Short time Fourier analysis [3, 4, llj 

c) Homomorphic analysis [ 3 , 4, 9, llj 

d) Formant analysis [l, 14] 

e) Analysis by linear prediction [5, 12, 15] 



2 . 2.1 Short Tine Autocorrelation Analysis 


This is a time domain analysis method wherein the 
utility of the autocorrelation function in displaying stiruc- 
ture in any waveform is employed. 

The autocorrelation f motion of a discrete time 
signal x(n) is defined as 

52 ^(m) = -Lira ■■ —-■ ■ 7 y S x(n) x(n + m) ( 2 . 1 ) 

N ^ CD ^ n=^N 


If the signal is periodic with period p i.e. 
x(n + p) = x(n) for all n, then it is easily shown that 

52r(m) = + p) (2.2) 


Thus periodicity in the autocorrelation function 
indicates periodicity in the signal. A lack of predictable 
structure in a signal is indicated by an autocorrelation 
function sharply peaked at m = 0 and falling off rapidly as 
m increases. 

Using the notion of short time analysis to operate 
on short segments of the speech signal, the short time auto- 
correlation fmction can be defined as 


1 

J2f^(m) = ^ S x^(n) x^(n + m) , 0 < m < - 1 

n=o 

( 2 . 3 ) 

where N = number a£ samples of a segment 
1 = beginning of the segment 

= maximum lag of interest and is >P if perio- 
dicity is to be observed. 



If N‘ = N, then data frcxn outside the seginent 
used in ccxnputation. 

If N‘ = N - iri/ then data from that interval oaly is 
reqiiired and the segment is often weighted by a ’’window'’ 
function that smoothly tapers the ends of the segment to 
zero. Either choice is satisfactory to detect periodicity 
in the speech. 

The direct computation of {Zf. (m) farO<m<M -l 

Jl w 

requires computational effort proportional to X N, which 
can be a significant overhead. 

The estimate of the autocorrelation is generally 
based upon 20 to 40 millisecond segments, making allowance 
that the window must be long enough to encompass at least 
two periods of the speech signal . 

2.2.2 Short Time Fourier Analysis 

This spectral analysis method is classic to the 
approach of obtaining the vocal tract transfer function. 
Speech is a quasi- stationary process and may be considered 
stationary for adequately short segments. Therefore the FT 
of a short segment of speech provides a good spectral repre- 
sentation of it during that interval. 

Figure 2.1 shows a simple way of implementing a 
short time spectral analyzer. The implementation inv- 
olves using a bank of bandpass filters. Choosing the 
filter pas sbands to, cover the speech band, the outputs can 
be thought of as a Fourier representation of the speech 
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signal, With carefully designed filters, the sum of all 
outputs will be a good approximation to the original speech 
signal. 

The discrete short time spectrum of x(n) is defined 
as 


X^(w) = 2 x(n) h(l - n) 

ni=- 00 

je. (w) 

= ] (w) 1 e 

.= a^(w) - j b^(w) 


(2.4a) 

(2-4b) 

(2.4c) 


Two basic interpretations can be made from equation (2.4a) j 

(a) X^-,(w) may be viewed as the FT of the sequence 
x(n) weighted by a window h(l - n) as in Figure 2.2. 

(b) The second interpretation follows the assumption 

that h(x) be the impulse response of a low pass digital 
filter, Assximing that it is desired to evaluate the short 
time transfoion at frequency w, from Figure 2.3(a) X^(w) is 
the output of a low-pass filter with input x(n)e'”‘^'^^. The 
depiction in Figure 2.3(b) avoids complex arithmetic and the 
output parameters obtained i.e, bj^(w),are the real 

and imaginary parts of the spectrum respectively. 

The choice of bandwidth of the bandpass filters of 
Figure 2.2 is discussed in Section 2.5.1 where the implemen- 
tation of the short time spectral analysis is realised in 
the channel vocoder. 



The short time spectral analysis may be performed 
using a FFT algorithm. When implemented on a computer, the 
FFT method is generally superior to the bank of filters model. 

2.2.3 Homomorphic Ana ly si s 

Homomorphic filtering is a class of non linear signal 
processing techniques that is based on a generalisation of 
the principie of superposition that defines linear systems 
[ 3 ]. It is a tool used to separate signals that have been 
non additively combined. Hence it serves to deconvolve the 
vocal tract and excitation functions. 

The basic operations of such an analyzer are depicted 
in Figure 2, 4(a). The signal at A is taken as a discrete 
convolution of the excitation and vocal tract impulse response. 
B is the result obtained by using a FFT and is the product of 
the FTs of vocal tract and impulse response. C is logarithm 
of the magnitude of the FT and is the sum of the logarithms 
of the excitation and vocal tract responses. Since the 
inverse DFT performed is linear, the result at D (called the 
cepstrum of input at A) is an additive combination of cepstra 
of the excitation and vocal tract components. Thus we have 
approximately transfoirmed convolution to addition. 

The cepstrum (D) serves as an excellent basis for 
estimating the fundamental period of voiced speech and for 
determining whether a particular speech segment is voiced 
or unvoiced [l3]. ■ 

The vocal tract transfer fxinction, or the spectrum 
envelope, can be cfctained by removing the rapidly varying 
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components of the log magnitude spectrum by linear filtering. 
One method is to multiply the cepstrum at D by a window that 
only passes the, short time components and then computing the 
DFT resulting in "E (Figure 2.4(b) and (c) for voiced and 
unvoiced speech segments) , 

2.2,4 Formant Analysis 

This method devolves around a time-frequency-intensity 
display of the short time spectrum of speech Icnown as a 
” speech spectrogram",. The vocal tract has resonances for 
voiced speech. The formant frequency is the frequency of the 
maximum of a gross concentration of energy in the spectrum of 
a speech sound. Fig, 2, 4(d) is one such spectogram. A wide 
band spectogram is preferred over a narrow' band one [3/ 7j 
since time resolution is relatively high and, in fact, the 
individtal periods of the time waveform are evident. During 
voiced intervals the vocal tract resonances appear clearly 
as dark bands in the spectogram. 

Formant analysis consists of a system which accepts 
speech as an input and yields output voltages whose magni-^ 
tudes, as functions of time, represent the frequencies of 
the formants. During the silent and unvoiced intervals of 
speech utterences the output voltages should be extrapolated 
continuoxisly [14], 

Such formant extraction is put to use in the 
terminal analog synthesiser. It also provides an interesting 
tool for clinical and therapeutical speech work. A large 
number of schemes have therefore been de viced for formant 
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frequency extra ction^ including by linear predictive analy- 
sis [5j. 


2.2.5 Analysis by Linear Prediction 

An alternative to the above methods is an approach 
based on estimating parameters of a vocal tract model. One 
such representation is in terms of a general rational transfer 
function of the form 


H(Z) 


G 


1 


q 

4- s 

1=1 



1 


p 

s 

lc«l 



(2,5) 


A speech segment is sufficiently complex that it 
cannot be expected to match exactly the above model of equa- 
tion (2.5). M-uch less, will be the matching to simplified 
all pole or all zero models. However, since a vocal tract 
transfer function is primarily characterised by resonances, 
it is fairly reasonable that an all pole model will preserve 
the important characteristics of the vocal tract transfer 
fvinction. Such an all pole, i.e. Autro Regressive, modelling 
techniqiie is called "Linear Prediction" [3, 5, 11, 12, 15] , 

A simplified modelling on this basis is illustrated 


in Figure 2.5. 

Consider that the time varying filter of Figure 2.5 
has a steady state system function of the form 


H(Z) 


X(Z) ^ 

Wm 


P 

- S 

Tc=l 




-k 


1 


( 2 . 6 ) 
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where X(Z) = 


S z 

X.=- 00 


(2.7) 


The speech samples x(n) are related to the excitation 
u(n) by the difference equation 


x(n-) = 2 a, x(n - k) + G u,(n) 

lc=l ^ 


^ ( 2 . 8 ) 


where G is the gain factor. 

Define a linear predictor systam (as in Figure 2,6) 
with predictor coefficients as a system whose output is 


x(n) 


2 a, . x(n - k) 
k=l ^ 


(2.9) 


The system function of the pth order linear predictor 


is the polynomial 


P(S) 


P -k 

S a z ^ 

k^l 


( 2 . 10 ) 


The prediction, error, e (n) is defined as 


e(n) = x(n) ~ x(n.) 


x(n.) - S a, x(n - k) 
k=l ^ 


( 2 . 11 ) 


From equation (2,11) it is seen that the prediction error 
seqtience is the output of a system whose transfer function 


A(2r) = 


S ®v ^ 
k=l ^ 


( 2 . 12 ) 


or A (z) 


1 - P (z) 


(2.1 a) 



Th\is the prediction error filter ^ A(z) will be an inverse 
filter for the system, hCz) of equation (2,6), i,e. 
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H(z) 


G 

A(z) 


(2.14) 


The basic problem of linear predictor analysis is to 
determine a set of predictor coefficients oc^, in such a 
manner as to obtain a good estimate of the spectral properties 
of the speech signal through the use of equation (2.14). A 
basic approach is to find a set of predictor coefficients to 
minimise the mean square error over a short segment of speech. 
The resulting parameters are then assumed to be the para- 
meters of the system function H(z) in the model of Figure 2.5, 
The short time prediction error average is defined 
as 


En = S 

m 

e^(m) 


(2.15) 

= S 
m 

(x^(ra) - 

x^(m))^ 

(2.16) 

= S 

x^(m) - 


(2.17.) 


m lc=l 

where x:j^(m) is a segpment of speech selected in the vicinity 
of sample n, and ra is temporarily left unspecified. 

The valxies ct^. can be foxind so as to minimise 
of equation (2.17) / by setting 

= 0 , i = 1, 2,...,p 

ther^y obtaining the set of equations 
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P 

S Xj^(ra ~ i) x^(in) = 2 S - 1) x^(ra - k) 

in k— 1 ■ nt 

(2,18) 

Frcm Equations (2,17) and (2.18) the minimum, mean squared 
error can be shown to be 


2 P 

Ejj^ = S Xj^(m) - 2 0^. 2 (2.19) 

m k=l 

It is now time to specify the duration m. If m is 
considered finite then we obtain a cross correlation matrix 
for the coefficients of equation (2.19) which is called a 
covariarrce matrix and has its methods of solution [3, 5/ lOj . 

However / we arrive at a simpler structured Toeplitz 
matrix if it is assumed that m is infinite and obtain the 
autocorrelation matrix for the coefficients of equation (2,19) , 


2.2. 5,1 Autocorrelation method [4] 

Here it is assume that m for equation (2.19) is 
infinite. Defining the autocorrelation of x^Crt'-) as 

00 

R^(i) = 2 Xj^(nr) x^(ni - i) (2.20) 

m==- OD 

Equations (2.18) and (2.19) respectively reduce to 


2 Rn(i - 
k=l 


1 < i < p 


( 2 . 21 ) 


and E. 


R^(o) + E a-^. R„(k) 
k=l ^ 


( 2 , 22 ) 
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Since the coefficients of equation (2.21) form an 

autocorrelation matrix, we derive the ’’autocorrelation method” , 
In matrix form equation (2.21) can be expressed as 


R„(o) 

Rj^(l) ... 

Rn(P-l) 


1 


R„(l) 

Rn(l) 

Rj^(o) ... 

• • • • 

Rn(P“2) 

• 


2 


R„(2) 

• 

• 

Nl^ 

* • • • 

• • « • 

Rji(l>-2) ... 

• 

• 

R„(o) 


<• 

P 


• 

• 


This pxp matrix is a Toeplitz matrix, the solution 
of which may be efficiently done by the Levinson Recursion 
as modified by Dxirbin [3, 4], 

As an additional consideration, a Toeplitz matrix 
is guaranteed to be non singular and hence the resulting all 
pole filter. However, in order to implement the autocorrela- 
tion method for short time speech segments we use an appro- 
priate w'indow function w(n) so that another signal x^(ra) , 
that is zero outside some interval o < m < N-l, is obtained. 
Then the autocorrelation method can be applied, to this x’(ra) . 


2 . 3 DURB IN ’ S RECURSIVE SOLUTION 


In the preceding section a Toeplitz matrix w'as 
obtained for the autocorrelation coefficients of equation 
(2.21). The procedure can be stated as follows: 



= R„(o) 


(2.23) 
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1 < i < P 

(2. 24) 

®i 

= ^i 


(2.25) 
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^i 1 < J < i-1 

(2.26) 

®n 

= (1 - k^) 

^(1-1) 

n 

(2.27) 


Equation (2.24) - (2.27) are solved recursively for 
i = 1/ 2,...,p and the final solution is given as 

“j = ccj^^ 1 < i < P (2.28) 

It is observed that in the process of solving for 
the predictor coefficients of a predictor of order p, the 
solutions for coefficients for predictors of lesser order 
have been obtained. 

Since, at each iteration, we obtain , it is easy 

to examine the error as the order increases. The set of 
intermediate parameters obtained are called •^reflection 
coefficients" and, in fact, corresponds to the reflection 
coefficients at the boundaries between successive sections 
of an acoustic tube vd. th sections of fixed length and 
varying cross sectional area. 

2.4 SYliTHBSIS METHODS 

of homomorphic and short time 
spectral analysis, two basic synthesizers are used for 



synthesis of speech from the analysis information; 

a) Terminal analog synthesizer 

b) Ac oils tic tube analog synthesizer. 

2.4.1 Terminal Analog Synthesizer 

Such a synthesizer [l] is directed at implementing 
a system whose transfer functicai approximates the vocal tract 
transfer function, but whose implementation bears no direct 
relation to the details of a vocal tract. The representation 
is only from a terminal view point. The basis of implemen- 
tation is that its transfer function can be approximated by 
a cascade combination of resonant circuits, each one repre- 
senting one of the modes of the vocal tract. Hence this type 
of a synthesizer is also called a ’’formant synthesizer” and 
its general structure is depicted in Figure 2.7. 

To correspond to changes in resonance due to change 
in the shape of the vocal tract, the resonant circuits are 
provided with a set of time varying parameters to control 
the centre frequency and bandwidth of the resonators. A 
source shaping filter provides appropriate spectral colora- 
tion when the excitation used for voiced speech is an impulse 
train and white noise for unvoiced speech, in addition, a 
filter that accounts for the effect of the coupling of the 
acoustic tx±>e into space is required. 

2.4.2 Acovistic Tube Analog synthesizer 

Figure 2.8 shows the representation of the vocal 
tract as an acoustic tiube [l, sj consisting of a set of 
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interconnected sections of equal length and varying cross 
sectional area. The assumptions made are: 

(a) The sound propagation through each section can 
be treated as a plane wave. 

(b) The internal losses and the effect of the nasal 
tract and coupling between the vocal tract and the glottis 
can be ignored. 

These assumptions -permit an analysis of the acoustic 
tube model which leads to a filter structure whose variables 
are related to the physical variables of the tube. The end 
result is the linear flow graph structure of Figure 2.9* 

This flow graph depicts the relationships between the 
forward and reverse travelling volume velocity waves through- 
out the acoustic tube of Figure 2,8, The coefficients r^/ 
n = 1/ 2 /., 4 ,m -1 are the reflection coefficients that charac- 
terise the sound produced at the lip end of the trobe. 

2.5 VOCODERS 

Having seen the various analysis and synthesis 
methods available, vocoders based on these methods are 
reviewed at block diagram level. 

a) Channel vocoder [l7j 

b) Homomorphic vocoder [3, 10, ll] 

c) vocoder based on Formant analysis [l, 14] 

d) LPG vocoder [15, 18]. 



2.5.1 Channel Vocoder 


The channel vocoder implements a short time spectral 
analysis on the speech segments as shown in Figure 2.10(a) 
and a synthesiser that is peculiar to this analysis method 
is show'n in Hgxire 2, 10(b), The filter bank method of anal- 
ysis is usedi It is pertinent to point out that these filter 
bands are desired to be wideband so as to yield a smoother 
spectrum (Figure 2.10(c))/ since the wider, filters average 
over several harmonics of the fundamental frequency. 

The number of filters is generally between 16 and 20, 
and the low pass smoothing following rectification is chosen 
to suppress the pitch ripple of 50 Hz and higher while 
passing the vocal tract spectral changes [llj . The pitch 
may be detected by any one of the several methods in 
Chapter 3. 

2.5.2 Homomorphic Vocoder 

The analyser and synthesizer for a homomorphic 
vocoder are shown in Figure 2.11. Here again the synthesizer 
is peculiar to the analysis method used. The vocal tract 
transfer fvnction V(nT) is obtained from the windowed 
cepstrum, as sxiggested earlier in Section 2.2.3. This is 
then convolved with the excitation parameters to obtain 
synthesised speech, 

2, 5. 3 Vocoders Based on Formant Analysis 

' ' ’ ■ ■ 

In Sec tion 2 . 2 . 4 it ha s been shown how formant 

frequencies can be extracted from a speech segment, studies 
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system; (a) analyicr configuration, (b) synthesiser configuration. 












show that the first three or four formants are enough to 
reproduce the speech in a terminal analog synthesiser. 

2.5.4 LPC Vocoder 

KLgtire 2,12 shows the major blocks needed to imple- 
ment a LPC vocoder [is]. The predictor coefficients are not 
really extracted for use in synthesis here. Rather, the 
reflecticfli coefficients, which are generated in the process 
of implementing recursive algorithms to solve the linear 
equations for predictor coefficients, are used for synthesis 
using an acoustic tube synthesiser. This follows from the 
fact that these reflection coefficients are found to corres- 
pond to the reflection coefficients at the boundaries of 
the fixed length sections of an acoustic tube. 

Such an implementation using the acoustic tube over- 
comes the pardblems [ 3 ] of using a direct form structure 
generated directly from the predictor coefficients, or a 
cascaded form obtained from factoring the all pole transfer 
function 
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2.6 SUMMARY 

This chapter reviewed the various analysis-synthesis 
systems available. Further work revolves around the imple- 
mentation of the hPC vocoder since it involves simpler hard- 
ware and Gonputation schemes. The excitation function ’which 
is sought to be separated in all the cases ^ is derived from 
a marioer of pitch period estimators mentioned in Chapter 3. 
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CHAPTER 3 

EXCITATION ANALYZERS 

3.1 PITCH PERIOD ESTIMATION 

Any analysis of the speech signal must provide , as 
the result, the vocal tract function and the excitation 
fxinction separately/ in one form or another. To this end a 
number of efficient pitch period estimation algorithms have 
been developed. All the algorithms provide the two distinct 
pieces of information that constitute the excitation function. 

(a) Whether a particular speech segrient is voiced or 
unvoiced and 

(b) if voiced, the pitch period of periodic excitation 
for that segpnent. 

The pitch period estimation algorithms available are: 

1) Modified autocorrelation method using clipping (AUTOC) 
(Figure 3,1) 

2) Cepstrum method (Figure 3.2) 

3) Simplified inverse filtering technique (SIFT) 

(Figure 3. 3) 

4) Data reducticai method (DARD) (Figure 3.4) 

5) Spectral equalisation. LPC method using Newton's 
transformation (LPC) (Figure 3,5) 

6) Average magnitude difference function (AMDF) 

(Figure 3.6) 

Parallel processing method (PPROC) (Figure 3.7) . 
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3.2 SELECTION FOR IMPLEMENTATI C»I 

The selection of an algorithm for implementation 
from, amongst the methods mentioned was made from a study [l3] 
based on the following criteria: 

1) Accuracy in estimating pitch period 

2) Accuracy in making a voiced- unvoiced decision 

3) Robustness of the measiirementS/ i.e. they must be 
modified for different transmission conditions, 
speakers^ etc, 

4) Speed of operation 

5) Complexity of the algorithm 

6) Sviitability for terdware implementation 

7) Cost of hardware implementation. 

Based on this study, it was decided to implement 
the Parallel processing algorithm (PPROC) of Gold and Rabiner 
6 for the following reasons: 

1) The parallel processing involved, helps produce fairly 
accurate pitch period estimates over a range of speakers, 

2) The algorithm is relatively straightforward and employs 
simple signal processing. 

3) A real time implementation was found feasible using off- 
the-shelf compcMnents. 

3.3 THE PARALLEL PROCESSING ALGORITHM 

Gold and Rabiner [e] proposed a means of obtaining 
pitch period estimates by parallel processing of the peak: 
and valley measurements made on the incoming speech signal 
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(Figure 3.7). These values/ named M- to are fed to six 

X o 

independent pitch extjractors or pitch period estimators. 

The estimates from these extractors/ obtained parallely, are 
put through a sophisticated comparison algorithm with a bias. 
The final decision of voiced and unvoiced segments is made 
based on the agreement among the six pitch extractors in the 
above comparison. For voiced segments, the most popular 
candidate in the cc»nparison is put out as the pitch period. 

However, to reduce the complexity of the peak and 
valley measurements/ a modified version of this algorithm, 
has been implemented. 

3.4 THE IMPLEMENTED MODIFICATION 

The modification/ called the second modification 
to the origirel parallel processing algorithm is discussed 
below. The block diagram is in Figure 3.8. The basic diff- 
erences from the original algorithm are discussed after 
pointing out that this modification is made on an assumption 
that fundamental frequencies are expected to be below 300 Hz. 
Based on this assumption the changes are: 

(1) The peak and valley measuremehts have been 
replaced by selective filtering through two Lemer filters 
with bandwidths 80-240 Hz and 200-600 Hz as shown. Further/ 
the filtered signals are fed into positive and negative 
peak: detectors. The outputs of these detectors are posi- 
tive pulses corresponding to the signal peaks, and whose 
magnitude is also equal to the peak magnitude of the signal 
at that point. 
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(2) The nijmber of pitch extractors or pitch period 
estimators (PPE) has been reduced to four, one for each 
negative and positive peafc detector. The detector consists 
of an exponential rvin down circxiit which is set to the value 
of the peak. Once set a blanking period follows during which 
peaks if any are ignored. At the end of the blanking dura- 
tion, the circuit is allowed to run down. If during this 
time any pulse comes which is greater in magnitude than the 
current run down value/ then the run down circuit is reset 
to that value and the time interval elapsed between the tw'o 
resets is put out as the pitch period (Figure 3.9), The 
original algorithm employed a variable blanking time and run 
down time constant based on the last pitch period average. 

In the implemented modification both these are fixed: 

a) The blanking intervals is fixed to 2 ms, 

b) The rim down time constant is such as to run down to 
half the initial value in 5 ms. 

In addition the run down circuit is reset after 
16 msec if no reset occurs, indicating an unvoiced segment, 

(3) The bias used in the original algorithm is 

removed and the final computation is performed by a coinci- 
dence check on the table formed in Figure 3,10. The coin- 
ci^nce measurements are conducted for the four roost recent 
estimates (^ 11 ' ^21' ^31' Each of these ’'candi- 

dates’* are compared with the other eleven (P^) and a score 
is maintained for each based on the inequality 



ip. 

8 ^i 


(3.1) 
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The voiced-unvoiced decisions are then made on the 
following basis: 

a) The candidate scoring maximum coincidences is put out 
as the pitch period, 

b) If any of the two candidates are 16 msecs or more than 
then an unvoiced or “hiss” decision is made. 

c) Also if no candidate gets at least 4 “votes”/ a hiss 
decision is made. 

Gold and Rabiner [s] have indicated that for the 
assumption that only fundamentals below 300 Hz are expected, 
the performance of the modified algorithm is reasonably 
good. 



45 


CHAPTER 4 

IMPLEMENTATIOJ OF THE PARALLEL PROCESSING 
PITCH PERIOD ESTIMATOR 

4.1 cast SIDE RATI OJS FOR THE DESIOSI 

The basic consideration for the design of the 
circuit and software for the implementation of PPROC algo- 
rithm has been: the use of off-the-shelf components. It was 
decided to \ise the 2912 line filter and the 2920 signal 
processing chips to implement the major signal processing 
functions. An initial attempt was made to realise the tw^o 
band pass filters using the 2912 line filters with 4 soft- 
ware peak detectors residing in the 2920. However this vras 
txirned down subsequently in favour of a final implementation 
in which the filters, peak, detectors and the run down cir- 
cuits were implemented on two 2920 ICS ther^y drastically 
redlining the chip count for the overall system. 

4.2 THE INITIAL ATTEMPT 

Based on the consideration that the cut off rates 
visualised by the 4 pole and 6 pole Lerner filters [23j 
could be equalled by the 2912 line filter, the scheme shown 
in Figure 4.1 was tried. A linear relationship was found 
to exist between the clock frequency to the 2912 filter and 
its cut off frequency. This property was used to derive 
the two band pass filters with pass bands as shown. The 
SAD 51 2D analog delay IC was used to compensate for the 
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additional delay in the signal through 2912(1). The 4 peak 
detectors were implemented in the 2920 and overall, the 
scheme worked upto this point. 

However, further implementation of the run down 
circuits and blanking intervals for the pitch period esti- 
mators was found to need a large number of components per 
channel. Hence this attempt was dropped and a more elegant 
final circ\xit was derived, 

4. 3 THE FINAL IMPLEMENTATION 

The initial attempt ran into problems when proce- 
ssing after peak detection was considered. However, 
rethinking suggested a better implementation resulting in 
easier control of the rxan down circuits and a reduced chip 
count. The hardware and software aspects are separately 
discussed in the following sections. The final circuit wras 
a single card containing the ICS as shown in Appendix A-l. 
This card provides the 4 parallel estimates of the pitch 
period and is plugged into the available workstation to 
perform the final computation. 

4.3.1 The Hardware 

A detailed circuit diagram is available in Appendix 
A-2 read with Appendix A- 3, 

Assxanir^ speech input from an ordinary telephone 
handset, a two- stage, front end amplifier using two 741s 
(U8, U9) has been implemented for the necessary gain. The 
speech signal is then passed through the 2912 line filter 



with the upper cut off frequency adjusted to 600 Hz using an 
NE555 clock (Ul). This signal is passed to the SIGINO pins 
of the two 2920 ICS (Ull^ U12), 

4.3.1. 1 Use of 2920 signal processor 

The pin layout is presented in Figure 4.2 for a 
2920 IC 21 , Notes on the 2920 signal processor and the 
use of the 2920 signal processing software package are 
appended at Appendix D. The two 2920 ICS (Ull, U12) 'teve 
been used in an identical manner. Each is provided with a 
6.144 MHz crystal which implies a 8 KHz sampling rate when 
the full program length of 192 instructions is used. The 
reference voltage for A/D and D/A conversion is provided by 
the set up of one LM 308 and two LM 103 voltage reference 
ICS (U2/ U3/ U4) . At the processor output pins the mode of 
output is controlled by the mode control pins 25 (M^) and 
24 (M 2 ). By fixing M^ at -5 volts and at +5 volts, the 
sigont pins 0-3 are made to provide TTL outputs. When 
external pull-up resistors are connected to these pins each 
has an output compatible to one TTl gate. 

Inside Ull is the software implementation of a 
4 pole Lerner filter, a positive and negative peak detector 
and two exponential run down circuits, one for each peak 
detector. The input signal is applied at pin 10 (sigin 0) 
and is sampled by the internal A/D convertor (Figxrre 4.2) 
under program control. The input sample is propagated 
through the software digital filter within and peaks are 
detected in the software peak detector s . Sigin 1 gets the 
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2 tns blanking pulse for the run down circirLt corresponding 
to positive peaks (PPEl of Appendix A-2). A TTL level pulse 
is output at pin sigcut 0 whenever the rxan down circuit is 
reset, similarly sigin 2 gets the 2 me blanking pulse for 
the negative peak run dow'n circuit (PPE2 of Appendix At. 2) 
and a TTL level pulse appears at pin sigc'ft 2 whenever this 
circuit is reset. 

U12 is similarly configured with the difference that 
a 6 Pole Lerner filter is implemented w'ithin. 

Pin sigin 3 is provided with -2 volts so that when 
sampled it serves to discharge the external sample and hold 
capacitor rapidly enough to prevent error in reading the 
input values on pins sigin 1 and Sigin 2. Sampling pins 
sigin 1 and 2 indicates whether the blanking pulses are 
present or not. 

The outputs of the 2920 ICS are bviffered using 4 of 
the 6 buffers in a 7407 (U33) , These 4 buffered pulses go 
one to each of the PPEs 1 to 4, 

4. 3,1.2 The pitch period estimators 

Four identical blocks, named PPE 1 to 4, perform 
the functions of 

a) providing a 2 ros blanking interval during which no run 
down occurs in the 2920. 

b) Counting the time interval betw'een t^wo successive 

from the 292GS, 

C) A pulse is output from the PPE to indicate that 16 ros 
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or more have elapsed between tw'o successive reset 
pulses of the run down circuit. 

The detailed circuit of a ppb is in Appendix A--3. 

PPE 1 will be discussed in detail to represent all the PPEs, 

The buffered pulse from the 2920 sigout pin is used 
to perform the following operations; 

a) Trigger on the rising edge, one of the two monostables 
of 74123 (U15) , to generate a 2 ms blanking pulse. 

b) Trigger on the falling edge, the second monostable whose 
outputs, Q and Q, are applied to the reset and trigger 
inputs of the XR 2240 counter (U25) to start a fresh 
coxant. 

c) strobe into the 8282 latch (U29) , on the falling edge, 
the latest count reached by the XR 2240 coxinter, i.e. 
the latest pitch period estimate. 

The XR 2240 counter is reset under the following 
conditions; 

No. 1 - When a count representing 16 msec is reached (i.e. 
when the 3 MSB are all 1), or 

Nd, 2 - A Q output from the monostable appears due to a s 

2920 output. ; 

The reset pulse is obtained by a logical OR of ! 

outputs of the monostable and the 4 input hand gate, 1/74 LS 20 
(U16). The output of the 4 input NAND gate is also used to 
trigger on the falling edge, one of the monostables in U5. 

The outputs Q, Q of this monostable are input to the latch | 
8282 (U7,) which is made transparent. Thus U now holds I 
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information that a 16 ms count has been exceeded in the 
concerned ppe . 

The 8282 .{U29) data is placed on the data bus when 
a CS is given to the OE pin of the 8282. This ^ is obta- 
ined under software control from the dual 1 out of 4 decoder 
74 LS 155 (U23) which uses lO/M*, A15/ A14/ A13 to decode 
the chip to be selected. 

4, 3.1. 3 The interrupt set-up 

In the previous sections it has been shown how the 
four 8282 latches (U29, U30/ U31/ U32) always hold the most 
recent pitch estimate. The fifth latch U7 holds the infor- 
mation as to which of the PPEs has exceeded 16 ms in the 
recent count. All this information is to be read into the 
microprocessor for final computation. 

The microprocessor is interrupted by an RST 7.5 
interrupt generated by the timer U13/ every 5 ms, suitably 
inverted by 1/7400 (Ul4) to meet the workstation requirements. 

The microprocessor puts out the pitch period infor- 
mation on the screen of the workstation for every other 
RST 7.5, i.e, effectively once for every 10 ms. This 
timing can be varied by varying the RC of timer U1 3 suitably, 

4.3.2 The Software 

The software used is implemented in two basic parts: 

1) 2920 signal processor software including aXerner filter, 

positive and negative peak, detector and run dcwn circuits 
for both positive and negative peaks (Appendices B-l & B- 2) 
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2) 8085 program for final pitch period ccxnputation 

(Appendix C) . 

4* 3. 2*1 2920 Signal Processor Soft'ware 

Printouts appended at Appendices B-i & B-2 contain 
the programs burnt into the PROM areas of Ull and Ul2 
respectively, 

for Ull^ the 4 pole Lerner filter has ccxnplex pole 
pairs at 80, 120/ 200/ 240 Hz along the jw axiS/ offset 80 
Hz to the left of the imaginary axis. 

For U12/ the 6 pole Lerner filter has complex pole 
pairs at 200 / 250 , 350 / 450 / 550 , 600 Hz along the jw axis, 
offset 100 Hz to the left of the imaginary axis. 

The pole locations and the Lerner filter implemen- 
tations are in Figure 4.3(a) and (b) respectively. High cut 
off rates are realised for such filters which are consti- 
tuted by summed outputs of parallel resonators [8/ 23], 

Extensive use of the SPAS 20 compiler [ 22} software 
available on the MDS-Intellec 2 system has been used to 
develop the filters/ talcing care of the intermediate over- 
flows, The output of each resonator is multiplied by an 
appropriate residue before summing as shown in Figiure 4. 3(b) , 
The adjustment of the gains was aided by simulating the 
filter using the correct sampling rate with the help of the 
2920 Simxilator fea] Software also available on tte MBS. 

The rest of the program is easily understcKxi 
the flow chart in Figure 4^4. BIT A and BIT B are used 
indicate whether or not a blanlcing pulse is present. If 
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Fig 4 J^flow Ctiift for 2920 Softwart 
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either is 1/ then the respective run down circuit is 
updated with the same value as it has been set with. The 
run down is allowed to continxae any time they drop to 0. 

A single peak detector algorithm has been implemen- 
ted which remembers the sign of the input signal and at the 
end gives out a positive or negative peak. This algorithm 
essentially compares 3 successive input samples and will put 
out as peak the centre Val\ie, when it is greater than the 
ones before and after it. This algorithm is show'n in 
Figure 4.5. 

For the run down circuit, the eqtation implemented 
is 

= 0.98219 y^j 

and simulates an exponential run down wdth the desired time 
constant, i.e. run down to half initial value in 5 ms. 

The analog output instructions OUT 0 and OUT 2 are 
used to output TTL level pulses at pins SigoWt 0 and Sigout 2 
corresponding to resets of the positive and negative run 
down circtdts respectively, 

4. 3.2.2 Final computation software 

Software for the final computation of the pitch 
period based on coincidence meas\irements for the latest 4 
estima.tes ^21' ^31" ^41 implemented as a program 

for the 8085 and fed into the workstation. 

A printout of the program is appended at Appendix C , 
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The pirogjrain has two inaxn parts: 

a) The background program, which currently wastes time but 
could be used for control and communications in a full 
vocoder implementation* 

b) The interrupt service routine which is entered each time 
RST 7,5 interrupt is caused by the timer on the card. 

The ISS has two parts: 

The first part is entered for the first RST 7.5 
received. The reset status word of U7 and the values from 
the 4 estimators are read into the second row of the table 

of Figure 3^10, l.e. ^ 12 ' ^22' ^32' ^42* esti- 

mator has indicated a reset of the counter caused by excee- 
ding a count for 16 ms,, then the value is corrected to 
Before leaving this part of the ISS and returning to the 
main program, a flag (CTRD) is set to 1 to indicate that the 
next time a RST 7.5 occurs, the second part of the ISS must 
be executed. 

The second part is entered on the next RST 7.5 
interrupt. This time all the five latches are read and the 
correct values for ^31^^41 filled in. Then 

^13 “ ’^12 Likewise ^ 33 ' ^43 

cc»np\ited and filled in. Next, one of the four eligible 
cattdi«3ates p^. (i.e. ^ 31 ' selected for 

comparison. The value 1/8 P^ is computed and stored. The 
selected Pj: is compared against the other B^s. Everytime 
the conditicxi P - V. > 1/8 p. is met, then the score in 

the appropriate counter is updated. In this way all the 4 
candidates are compared. 
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Finally the scores in the respective coianters are 
ccxnpared and the majority winner is output as the pitch 
period. 

However if the nejority winner fails to mal<B a 
score of at least 4, then a “hiss” decision is made. Also 
if any two or more of the candidates are then again a 

’’hiss” decision is made. 

In the above implementation one observation made 
is that if the pitch changes suddenly between two 10 ms 
segments then a hiss decision is made before the new pitch 
period is put out. Appropriate interpolation at the 
receiver is litely to overcome this problem. 
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CHAPTER 5 

SUGGESTIONS FOR FURTHER WORK 

5.1 IMPROVEMINTS FOR PRESENT IMPLEMENTATION 

The present implementation has been based on avail- 
able components. However the ccmiplete circuit beyond the 
2920 ICS may be drastically reduced in component count by 
using 8253 programmable interval timer/coijntex , Figure 5.1. 

The advantages perceived in implementing the counters 
on the 8253' may be listed as under: 

a) Drastically reduced component count both in the number 
of IC's and passive components, 

b) Reduction in the power consumption vcould be svibstantial 
since only two 8253 are sufficient to implement all the 
four coulters as vcell as have timers to provide the 
timing for the interrupt control. The 8282 latches 
each consuming 1 watt power can be dispensed wuth, 

c) The total nuntoer of monostables used at present is 
eight. Changing over to 8253 provides automatically 
for the conditions when count exceeds 16 msec. There- 
fore only four monostables need to be retained for 
providing the blanking pulses. 

d) The additional logic circuitory used for reset of 

the XR 2240 is therefore automatically dispensed with. 

e) Higher precision may be achieved since the individual 
pitch period estimates can be made on 16 bit counters 



Fig 5.1 Block diagram for suggested impre 
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as against 8 bits in the present implementation. 

5*2 SUGGESTED SCHEME FOR THE REALISATION OF LPC VOCODER 

The pitch period estimator implemented can be used 
as the excitation analyser for an LPC vocoder based on the 
schematic of Figure 5.2, study has shown the feasibility 
of such a project [l9j. The major signal processing hardware 
required is a catbination filter-codec (ami S3 507) and two 
Signal Processing Interfaces (SPI) . One SPI is used to 
implement the LPC analyzer and the other an acoustic txbe 
synthesizer. The SPI used can be the ami S2811 or the 
eqtii valent NEC PD 7720, both of which are well suited. 

The 8085 is used for data transfer, control and multiplexing 
functions- along with communications with the host terminal. 
The overall scheme of implementation corresponds to that 
shown in Figtire 2,12, 

5,2.1 Analyzer Implementation 

The analyzer is a windowed autocorrelator followed 
by Durioin's recursion to eval\aate the reflection coefficients 
(Section 2. 3) , The SPI receives speech samples as serial 
data from the combo codec-filter, once per analysis firame, 
on command from the control processor during an A/D inter- 
rupt service. The received speech samples are weighted by 
a Hamming window and the P+1 correlation coefficients are 
computed for the current frame. This computation concludes 

the i^nterruptvSer^ce routine./^ 



ized 


8 Bit Hicrocomputer 
Data bus 


■4-v^ 

Clock 
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Tiiiurig 


a| 5.2 LPC Vocoder Architecture 
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The background routine in the SPI computes the LPC 
reflection coefficients passed from the interrupt service 
routine above. This computation/ also/ is performed once 
per frame on command from the control processor. The end 
result, of the computation is an array consisting of P refl- 
ection coefficients and the prediction residvjal energy, 
parameter coding is implemented in the control processor in 
order to maintain the flexibility of the SPI analyzer. The 
analysis ftame length is 22,5 ms for 8 KHz sampling rate 
for an intended predictor order often. 

The pitch period estimator already implemented can 
provide a pitch estimate/m voiced decision once per the 22,5 
ms frame. 

5,2.2 Synthesizer Implementation 

In each frame/ the SPI synthesizer receives an 
energy estimate, pitch/voicing decision, and a set of reflec 
tion coefficients from the control and ccmmuni cat ions micro- 
processor. The synthesizer reconstructs the speech and 
outputs it as PCM data through the SPI serial output port. 
The synthesizer consists of an excitation generator, a 
lattice (acoustic tube) filter and a one pole de-emphasis 
filter. The lattice filter coefficients are obtained from 

a Unearinterpolation of the past and present frame- s 

reflection coefficients. In voiced frames, the filter 
excitation is a pulse train with pitch equal to the esti- 
mate and amplitude based on a linear xnterpolation of the 
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can be drastically reduced as suggested. Lack of a facility 
to test the estimator for real speech input samples irliibits 
comments on its performance though tests have otherwise 
^ow'n it to be fairly accurate in the extraction of pitcJi 
period of signals generated using a Laboratory functicaa 


generator. 
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h i.... A i..‘i i K. l‘"“ i) } l.‘ 1^1 1 j 5 

i £i7 

1 1 7 

F393EF 

LDA 

FLAG, KP2, CND7 

1 88 

118 

4489EF 

LDA 

BEE, SAVE 

1 89 

119 

448;l.EB 

SUB 

BEE, CEE 

i. 90 

1 20 

42C4E5 

LIM 

DAF6 BEr£ 

1 9 1 

121 

F''-393ED 

ADD 

FLAUi KP’Lj CND/ 


1 2:2 

4093FF 

L...DA 

PEAK, KPO 

1 93 

123 

4SC4EF 

L..DA 

DAF7’ h i...Au 

194 

Hi 4 

4000i“.F 

NOP 


195 

1 '.25 

4000EF 

NOP 


196 

126 

F199FF 

L.DA 

PEAK, SAVE, CND7 

197 

1 21 

448 lEF 

LDA 

BEE, CEE 

198! 

128 

4489FF 

LDA 

AYE, SAVE 

199 

129 

4A6CEF 

LDA 

DAR, NEGVAL 

200 

130 

4493EF 

LDA 

NPEAK, KPO 

201 

131 

4C99FF 

l-DA 

PPEAK, PEAK 

202 

1 3:2 

F593FF 

LDA 

PF^'EAK, KPO. CND7 

2 .OS 1 

1 33 

FD99EF 

LDA 

NF'EAK, F'E.AK, uND.''' 

204 

134 

406‘^l-Ei!F 

LDA 

DAR, BITA 

205 

135 

4000EF 

NOP 


206 

136 

F593FF 

L.D A 

PPEAK, KPO, CND7 

2.07 

137 

4A64EF 

LDA 

DAR, BITB 

208 

138 

40G0EF 

NOP 


2.0’9 

1 39 

F593EF 

LDA 

NPEAK, KPO, CND7 

2 1 0 

140 

40E9EF 

LDA 

PSTORE, PCRDV 

211 

141 

4AC9FE 

SUB 

PCRDV, PPEAK 

212 

142 

40ECE5 

LIM 

DAR, PCF<DV 


143 

4EEBEF 

LDA 

PINFO, KMl 

214 

144 

7EC9FF 

LDA 

POSPK, PPEAK, CNDS 


Di£Tf“CTION AND RUN DOWN Si 


E'r A THRESHOLD FOR INPUT 


"CTION 

SIGNAL LEVEL 



.I'.-;-- .11 



iiLEFo 

VI. 0 







PAGE 5 


lini?: 

LOC 

uBJEICT 

SOUF 

'.CE STf 

Pn-MENT 








215 

1 45 

7CCBi::;.F 


P'lMFO,. 

SCP5, LO; 

i. , CND 







2 1 6 

;l 46 

42E4E5 

LIM 

'DAR, PI 

! IMFO 








21 7 

1 4-7 

40EiFF 

LDA 

PCRDV, 

FB 1 L.iKE. 








:2 1 S 

1 48 

F3E9FF‘ 

LB A 

PCRDV, 

POSPK, t 

::1MD7 







2 1 9 

:l 4'9 

SOOOEF' 

OUT'C 










220 

150 

300GEF" 

OUTC 

i 









22 1 

151 

SOOOEF 

OUTX 

i 









22!2 

1 52 

SOOOEJ"* 

OUTC 

) 










1 53 

SOOOEF 

OUTO 









224 

1 5^i> 

800012 

OLITO 










1 55 

48F9EF 

LDA 

NSTORF 

:,} NCFiljV 








226 

1 56 

4AD1FB 

SUB 

MCRDVU 

NPEAK 








227 

157 

4851CE5 

l;i;h 

DAR, NC 

;;RDV 








fcW •?**• 

158 

4EFBEF 

L'DA 

NINFO, 

KMl 








4*.. *7* 

1 59 

7ED1FF 

L.DA 

NEGPK , 

NPEAK, i; 

,:’.NDS 







230 

1 6C) 

■/'CDBCF 

LDA 

NINFO, 

KP'3} LO; 

1 , CND 

s 






23 1 

161 

4AE4E5 

l:i;m 

iJAhw M. 

lNFO 








232 

J. Cl' .I'f. 

48F1FF 

LDA 

NUl“‘-! D V ; 

NSTORE 








.c'. '.!> 

1 63 

FBF9FF 

L.DA 

NCRDV, 

14EGF‘K/ ( 

;:.ND7 







234 

16. 4 

ttU<.iUl:'.F 

0UT2 









235 

165 

AOOOEF 

OUT! 










236 

1 66 

AOOOEF 

OUTl 

> 









237 

1 67 

AOOOEF' 

0UT2 









23 B 

1 68 

AOOOEF 

0UT2 









239 

1 69 

AOOOEF' 

0UT2 









240 

170 

4.064EF 

LDA 

DAF<, b; 

FT A 








241 

171 

4000EF 

NOP 










242 

172 

F3E9FF 

LDA 

PCRDV, 

POSPK, 1 

:.:ND7 







243 

17' 3 

4A64EF 

LDA 

DAR, b: 

ITB 








244 

174 

40ace;f 

LliH 

PY , PCI' 

•<DV 








245 

1 75 

FBF9FF 

LDA 

NCRDV, 

r SMEOPK, 1 

::;ND7 







246 

1 76 

40ACAA 

SUB 

PY, PCf 

■PDV, R06 








247 

177 

40AC0B 

SUB 

PY, PCS 

^!DV, R09 








2-1’S 

;i. 73 

400.64D 

ADD 

PY, PY, 

, R1 1 








249 



i PY= 

9829: 

iCiS^PCR; 

DV 


-“THE 

: ACTUAL 

FACTOR 

DESIRED WAS 0. 

9328206 

"'y 3;u| 

179 

4043FF" 

LDA 

PCRDV, 

, S"‘Y 

; PC 

;RDV 

HAS 

l,..ATEST 

RUNDOWN 

VALUE 


251 

180 

48ACFF 

LDA 

NY, NCRDV 








252 

181 

4SACBA 

SUB 

NY, MCI 

RDVL R06 








253 

132 

48 AC IB 

SUB 

NY, NCI 

“<DV, R09 








254 

1 83 

‘400E5E1 

ADD 

NY, NY, 

, Rll 








255 



i NY== 

9829 

1.056*NCi 

RDV~- 

— 

“THE 

Same I:£N 

ROR EXS] 

lTS 


•7SA 

*.„• 

1S4 

405BFF 

L. 11 A 

NCRDV, 

, NY 

i NC 

•.RDV 

HAS 

NON THE 

LATEST 

RUNDOWN VALUE 

FOR NEGATIVE PEAKS 

257 

185 

4000EF 

NOP 










258 

1 86 

4000EF 

NOP 










259 

187 

4000EF 

NOP 










260 

188 

5000EF 

EOF 










26 1 

189 

4000EF 

NOP 










262 

190 

4000EF 

NOP 










263 

191 

4.000EF 

NOP 










264 



END 









' ■■ ■ ■ 

SYMBOL: 





VALUE 












ASSEMBLER VI. 0 


PAGE 6 


WPUT 

0 

INO-i-PO 

1 

INO"i"Pt 

I NO-'r-P'Z 

■I*" 

I NO-''>P '.:'.! 

1 

OUT2-‘'"’PO 

TEMP 


OUT 1 -'r'PO 


0UT0't"F'0 


0UT2"rpl 


OUT;i.-«"P:i. 

Y", 

OUTO-'rF'l 

7 

0UT2";-P2 

B .!. 1 A 

8 

OUTi-'rp2 

C/ 

0U"l"0-rrP2 

iO 

0iJT2t-P3 


OUT i 3 

;ll 

OU T 

12 

OUTF'UT 

13 

BITB 

14 

MEGVAL 

15 

CEE 

16 

SAVE 

17 

fc'l-l"" 

18 

AYE 

1 y 

F~l,.,.ACi 

20 

PEAK 

2:i 

NPEAK 



F'PEAK 

23 

PSTORE 

24 

PCBlDV 


PIMFO 

26 

POSF'K 


NSTOF:E 


r4Ch;DV 

29 

iMIMFO 

30 






3i 

PY 

p*» 2 

MY 



ASSEMiBLY COMPLETE 
ERRORS = 0 

WAIn’MIlMGS 0 


J. . 1 . 


••• V.' i:::. n i... s;;:. V X . 0 

ASSEMBLiE:R INVOKED BY; ;F1:AS2920 FINFIL 


NE 

L.,00- 

Oki.JECT 

SOUFiCE STATEMENT 

1 

.s«- 



A./D CONVERSION i 


0 

0066EB 

SUB DAR, : 

4 

1 

OOOOEr 

I NO 

5 

2 

OOOOEF 

I NO 



00001:" F' 

INC 

7 

4 

5 

OOOOEIF 

f ii- p 

I NO 

9 

A, 

OOOOIEF' 

I 'lU 

1 NO 

1 0 

..... 

4000E:!F‘ 

NOP 

;i. 1 


6000tlF 

C-VTS 

1 \ui 

9 

EBE6ED 

ADD DAR, 1 

1 3 

1 0 

4000EF 

NOP 

14 

1 1 

7100EF 

CVT7 

15 

12 

4000EF 

NOP 

16 

1 3 

6100EF 

cvr6 

1 7 



0UT2^"P0 EQU TEMP 

18 

1 4 

4008E.F 

l,..DA 0UT2-e-P0, OUTl' 

19 



i 0UT2"rP0™l, ' 

20 

15 

5300FT-" 

LDA OUTi «"PO, OUTO' 

2 1 



i out1''~po==!;l i 


J. 6 

44004E 

LDA OUTO-s-PO, 0UT2 

23 



i 0UT0-''.-F‘0~!0. 


1 7' 

4500EB 

SUB OiJTO-«"PO, 0UT2 

25 



i 0 U T 0 <r F-' 0 " "" 0 


18 

4600SA 

SUE OUTO-rPO, OUTO 

27 



; 0 U T 0 p 0 “• 0 


19 

37002E 

SUE QiJTO";”PO, OUTO 

29 



; 0UT0ir-F’0--==--0 

30 

20 

4400CA 

SUB OUTO-'^-PO, 0UT2 

31 



; OUT O'^'P 0~'“'0 


2 1 

250SCD 

ADD 0UT0-<-P0, OUTl 




i 0UT0''i"P0™2. ' 

34 

!2 

4408‘^I-A 

SUB OUTO-t-PO, OUTl' 

35 



j ■ 0 U T 0 P 0 ~ 1 . ' 

36 


1 5086A 

SUB OUTO^rPO, OUTl 

■Z\'J 



i OUTO-rPO=l. 1 

2‘ »m» 


4 4 08 AC 

ADD OUTO-H-PO, OUTl 


ION F'oOUTINE ADDED BY liACi-?0 ADCONv 


OOOOOOf 


yuoouoo 


25 05080B SUB OUTO’-i-F'OHliUTi s-F'O. RO'jV CV iO 

; OUTO-'rPO"!. 82.6 171 8*0LiT;l''’“P0--G. 8546409 l*OiJT2.-''"PO 

26 4000EIF NOP 

27 4422FF LDA INPUT, DAR 

28 42iSCE LDA IlMO-rPO, INPUT, R07 ; INPUT SCALING IS EFECTEID HERE 

29 42;lSBE LDA XNO'^Pl , INPUT, F<06 

IN0<-P2 EQU INO-«-Pl 
INO'rPS EQU INO-'^Pl 
IN0-«-P4 EQU INO-^-Pi 
IN0-H“'5 EQU INO-v-Pl 

30 4C00ED ADD OUTO'S-PO, INO«-PO, ROO 

i 0UT0-«-F‘0'”l. S^fSlTlS’SCiUTls-PO-O. 8546409 1 *0UT2-«-P0-!- 1. 00000000«-IN0-5-P0 
0UT2«'P1 EQU TEMP 



J.O j. •: 


i* -s* 


^ ja: 


V.I.. u PAGE \: 

I ME 

L..QC 

OI:;i..JECT 

SOUF 

■;CE STATEMENT 


31 

4A00EF 

EDA 

IJU'T 2 1 A Oi..J’'r 1 -^-F^ 1 ^ |3CiC> 

54 




i U U i ‘Z F‘ !l. 1 , 00000 0 0 0 '"’i' 0 U T 1 F* 1 


32 

4Ei8EF 

L.DA 

uUTl-S'Pl , i:il..iTO->F'l, ROO 

56 




i OUT I'Jrp 1 0000 OOOO-^' OUT 0-‘j”P 1 

57 


4f£ 107E 

LDA 

OUTO-?-P 1 , OUT 1 -H-P 1 . R04 

58 




f U 1 J i D r-‘ 1 0 . 0 6 2! 5 0 0 0 0 0 0 U 1 1 F*‘ 1 

59 

34 

41EI 1 03A 


OUTO^i-p 1 . U1..1T 1 -i-p 1 . R02 

60 




f 1. j U 1 •-.> !”•’ 1 •- 0 . 1 8 ’7 5 0 0 0 0 0 1 J 1 1 P 1 

61 

35 

4E 1 ODD 

ADD 

OUTO-'I-P 1 , OLiT 1 -i-p 1 , L,.0 1 





; OUTO-'rP 1 = 1 . 8 1 25000*01.0' 1 "i-P 1 

6i’‘i 

36 

•41:;;, 1 fclbD 

ADD 

OUTO-‘i"P 1 , OUTO'«-P 1 , R 1 1 

5-‘4 




; OU'rO-'i-P 1 = 1 , S 1 33850*0UT 1 "rP 1 

6' t.' 

37 

44 1 0F£8 

!3Ui:5 

OUTO-H-Pl , 0UT24-P1 , ROO 

66* 




; OLlTO-ii-'P 1 1 , S 1 33850*0UT 1 -'rP 1 ;1. . OOOOOOOO-^OUTi'Z-^-P 1 

67 

:38 

•^■t'4 1. 05C 

ADD 

ou "ro-«-Pi 1 our:;':->;~F'i .• F;03 

68 




; UU r 1 — 1 . S 1 33850‘5?'0U T 1 -‘V-P 1 -"‘O. 87500000*J^*0UT2'’i“P 1 

69 

39 

44 1 OBC 

ADD 

OUTO-i-F' 1 . 0UT2-':-P 1 , F506 

70 




i OUTO'i-'P 1 =- 1 . 8 1 33850*0UT 1 •‘'"•P 1 ■•••■0. S5937500*0UT2-‘i-P 1 

7 1 

•^'1-0 

4- 4 1 OFC 

ADD 

OUTO-i-P 1 » OUT2'6-P 1 ^ R09 ' 

7 2 




i OUT O-'rP 1 -™ 1 . 8 1 33850*0UT 1 "rP ;i. -0. S5546375*0UT2-:"P 1 

73 

4 1 

4-'’;i' 1 Ci3D 

ADD 

OUTO-«-Pl/ 0UT2"rPl , RIO 

74 




i OUTO•<^•F* 1 1 . 8 1 33850*^^0UT 1 1 -0. 8544921 S^-OUl^J’rP 1 

75 

42 

44 1 09B 

SUB 

OUTO -:-Pl. CfUT2’«-F'l, R13 

76 




i OUT 0-«"P ;l ==• 1 . 8 1 33S50*0UT ;l -i-P 1 --O. 8546 1 425*0UT2^Hp 1 

77 

43 

4C13FD 

ADD 

OUTO-rP 1 , 1 'MO-eP 1 ; ROO 

'/ f**‘i 

44 

1 066EB 

SUB 

DAR,. DAR, ;f.Mi ; START ACQUIRING BIT 

79 




1 0UT0-6-P 1 == 1 . 8 1 33850*0UT 1. ’H-P 1 --0. 8546 1 425*0UT2-^P 1 + 1 

80 



OUT;; 

T';-P2 EQU TEMP 

8 1 

45 

1020EF 

I..DA 

0UT2S-P2, 0UT1";--F'2. ROO, INI 

C.< •'“« 




i 0 U T 2. ■‘r P 2 = '.L 0 0 0 0 0 0 0 0 * 0 U T 1 •'i" P .2 

83 

46 

106SEF 

LDA 

0U'T'1’<-P:2, 0UT0*F'2, ROO, INI 

84 




; 0UTl''rP2.""=-i. 00000000*OUTO-'i-F‘2 

35 

4.7 

1 0405E 

LDA 

0UT0-'i-P2, 0i..lT2-«-P2, R03, INI 

86 




i 0 U T 0 P 2. "• 0 . 1 2 5 0 0 0 0 0 0 * 0 U T 2; •‘r F‘ '2 

87 

48 

1040FB 

SUB 

0UT0-i-P2, 0UT2-H-P2, ROO, INI 

88 




; 0UT0-«"P2=~0. 8"/'500000-iH:iUT2''rP2 

89 

49 

1068DA 

SUB 

0U'T0''i"F‘2:, 0'UT0*F-':2, F<0'7, INI 

90 




j OUTO''rF''.2=~"“0. 86811 6406*OUT;2'‘i"P;;i 

91 

50 

1 U 6 *n:'DA 

SUB 

0UT0'«"F*2, 0UT0-'i"P2, Fi07, INI 

92 




i 0I.JT0''i-P2~"“0. S613S;l54*0UT2-^P2. 

Q ‘ 

51 

4068DA 

SUB 

0UT0-«-P2, 0UT0«-P;2, R07, NOF'* 

94 




i 0UT0'i-P:'Z="-""0. 85465:1 95*0UT2'fr-P2 

95 

52 

6060 DD 

ADD 

i:iUT 04 -p 2 , OUT 1 -rPa, lo i , cvrs 

96 




i 0UT0'*rP;;i'.“-'2. 0000000*0UT 1 -'r-Pz-O. 85465 ;l 95*0UT;2''rP2 

97 

‘"ti 

•40603A 

SUB 

OUTO-^-PlZ, 0UTl 'i~P2, R02 

98 




i 0UT0<"P2=~1. 7500000*CiUTl«-P2.~~0. 85465 ;195*0UT24-P2 

99 

54 

EBE 6 ED 

ADD 

DAR, i<M2, ROO, CND 6 ; A/D CGNV INST 

100 

55 

40609C 

ADD 

0UT0«T-’2, 0UTi^P2, R05, NOP 

101 




i QUT0-«-P2“ 1 . '78 1 2500*0UT 1 +;-P2“"0. 85465 1 95 -k-CiUT2-«-P2 

102 

56 

7 160 IB 

SUB 

0UT0*;T“’2, 0UT1«P2, R09, CVT7 

103 




i CiUT0-s-P2~l. 7792968-sOUT l-«-P2~0. 85465 195*0UT2-«-P2 

ION- 

57 

40607D 

ADD 

0UT0''rP2, C.iUTl-'rF'2, R12 

ICS 




i 0UT0*-P2“ 1 . 779154 1 0 * 0 UT 1 ♦:-P2“0. 85465 1 95*0UT2-rP2 

106 



; I Mi; 

:LUDE TWO INST TO SET BIT A 


. OOOOOOc 


0 0 0 0 I. H <3 P 1 


0000000 



,1 . 5 . 


V . 1 . . \J 


F'‘AGE 


INE 

i...OC 

OB...,iEC."r 

SOURCE STATEHENT 

1 07 

53 

FDCACF 

LDA 

BIT A) KPS, LOl, CND7 

iOS 

59 

74C2EF 

l.,DA 

BITAi KPO^ ROOi CNDS 

i09 

no 

60 

484St-"B 

; CONTINUE FILTERING 

ADD 0UT0-V-P2, IN0^i-P2, ROO 

1 1 1 
i;l.2 
113 

61 

322SEF 

OUT;; 

LDA 

i 0UT0-'r'P2=-- 1 . 7'7954 1 0-s-OU'T 1 "i-PlZ-O. 85465 1 SS-s-OUl'Z-rP?-!- 1 OOOOOOOO-s I NO-^f-p:.'' 
EQU TEHP 

0UT2<-P3 , OUT 1 •>rP3 , ROO , I N3 

mi- 

ns 


3C60i-4~ 

LDA 

1 U U f ’ 2 -‘v- F' 3 "=nL 0 0 0 0 0 0 0 0 -ft- 0 U X 1 P 3 
iJU T 1 ‘‘i-F’S .« 0U"r0-JrF'3 j F;00 j I N3 

116 

117 

6 n! 

:30S»C)4IE 

LDA 

; U U 1 1 •'i" P 3 1 , 0 0 0 0 0 0 0 0 0 U T 0 "i" P '3 

0LIT0-^P3, 0UT2-i"P3, R03, IN:3 

118 

1 1 9 

64 

:30501EB 

SiJB 

; OUT 0-'i"P3==0. 1 25000000*0U"l"2-';-P3 

0UT0'«-P3, OLjTa-rPS, FilOO, IN3 

•j 2.0 
121 

65 

3870 AA 

SUE 

f UUT0*’rF*'3-==*’‘"0. 87500000-5^’0U T 2-'i"F*‘3 

UU 1 LJUI U’‘^''F‘3.‘ F''!06.i IF4c5 

123 

66 

30502D 

ADD 

! OUT0^rP3==-0. 86 1 328 1 2*0UT2'=rP3 

0UT0'«"P3 , 01JT2"rP3 , R 1 0 , I N3 


67 

4370CA 

SUB 

i UU i 0’^"P3i"-"“0. 8<:'03!5 1 S'S^OU i 

0U"f0-'i~P3, 0UT0-'rP3, R07 

1 26 
127 

/"t j"’i 

4050;2E 

SUB 

i 0UT0'«"P3~--0. SSSSSOOT-iHDLriT'Z-'r-PS 

0UT0-'rP3, 0UT2-H-P3, F^IO 

i *'70 

<U 4%**»*»^ 

129 

69 

4273C:D 

ADD 

t 0UT0•’^•P3— —O. 85 460664 OUT 2 ‘rF’ 3 

0UT0'*i*‘F’‘3/ OUT LOl 

131 

70 

42'782A 

SUB 

; OUTOS"P3“:2. OOOOOOO-s-OUT 1 •'i-P3--0. 85-460664*OUT2-’r-P3 

0UT0-.;-P3, 0UTn-P3, R02 

133 

7 i 

427SAA 

SUB 

i OU'TO-ii-P3“ 1 . 7500000*0UT 1 "S-F'S-'-O. S5460664*0UT2'‘rP3 

0UT0<"P3, 0UTnP3> R06 

134 

135 

7? 

42786D 

ADD 

i 0UT0-':"P3“-1 . 7343750*0UT 1 ■•rP3-"0. 85460664*DUT2''rP3 

0UT0-‘rP3, 0UT1'4-P3/R12 

136 

137 

73 

4S5SED 

ADD 

; 0UT0->i-F63-."i. 73461 Rl-s-OUTl-'rPS-O. 85460664*0UT2''rP3 

0UT0-‘rF'3, INO-^-F'S, iROO 

138 

140 

7^!- 

2066EB 

OUTl 

SUB 

; 0UT0«-F‘3= 1 . 7346 1 9 1 -s-OUT 1 -^-PSi-O. 8546066.4*0UT2-^F‘3-i- 1 . OOOOOOOO-s- 1 N0-«-P3 
?.-rP4 EQU TEMP 

DAR, DAR, iR00n;N2 ; START ACQUIRING BIT B 

141 

75 

■2828EF 

LDA 

0UT2'rP4, 0UTi^rP4, ROOi 'IN2 

1 -4 '.2 
143 

76 

2A70FF 

LDA 

i 0UT2-«-P4=l. 00000000'S^0UTl-«-P4 

0UTl -rP4, 0UTo-«~P4, ROO, ;tN2 

144 

145 

77 

2:C780C 

ADD 

} 0UTl-'i"F’4=l. 00000000-^OUTO-'i-P4 

0UT0-'i-P4, 0LnTLrP4, ROi, IN2 

146 

147' 

78 

2C7S4C; 

ADD 

j 0UT0-^-P4==l. 00000000-»OUTO'':-F-'4"i'0, 50000000*0UTl-»:-P‘^l- 
0UT0''rP4, DUT1^;-P4, R03, IN2 

148 

149 

79 

2.Er70SC 

ADD 

i 0UT0-^-P4-"l. 00000000*0UT0-'rF'4+0. 6.2500000*0UTl-«-P4 

0UT0''i"F'4, 0UT0’'i"P4, B:05, IN2. 

150 

ii.-i 

80 

4E700D 

ADD 

i 0UT0-'rP4=l. 03 12S000*CiUT0-':-F‘4-^"O. 64453 125*0UT1-6-P4 

0UT0«-P4, 0UT0'H-P4, R09 

152 

81 

6450EI3 

SUB 

i 0UT0'«-P4™1. 033264 1 6*0UT0-«"P4+0. 64579008*OUTn-P4 

0UT0«'P4, 0UT2<"P4, ROO, CVTS 

154 

155 

•*”« 2 

44504C 

ADD 

; 0UT0-«-P4= 1 . 033264 1 6*0UT0-':-P4+0. 64579008*0UT 1 4-P4-- 1 . 00000000'ji'0UT2-«-P4 
0UT0-«"P4, 0UT2-^P4, R03 

156 

157 

R3 

EBE6ED 

ADD 

i 01JT0''."P4=1. 033264 16»OUTO*;-P4-i-0. 64579008«-0UTl-<"P4~-0. 87500000*OUT2-«-P4 
DAR,KM2,CMD6 > A/D CONV INST 

158 

84 

4-450AC 

ADD 

0UT0''i"F'4, 0UT2'.'^‘F'’4, R06< 

159 

160 

85 

7550EC 

ADD 

: 0UT0'fi"P4“ 1 . 033264 1 6*0UT 0-‘!"F'4+0. 64579008-S’OUT 1 •«"F''4--0. 35937500'S5-0UT2'<"P4 
0UT0''’rP4, 0UT2.-'rP4, R08, CVT7 


. 00000C?< 


: OOOOOOd 






V L . *.J 


PAGE 


INE 

L.0C 

OBJECT 

SOUF 

;c;E stateme;mt 

161 




i UU i L 033264 i6-i^0UT0'':3"’'4"i"0. 645790C^8-i^7)UT S5546875-^0i rr24*F'4 

1 t/z 

‘l"’ c.* 

445«..:'2D 

ADD 

0UT0-'rP4! 0UT2-‘rp4; RIO 

1 6:j:J 




f UU T0’^“F'4- i . 033264 1 6-^0UT0‘*:"P4-i"0. 645 7900S'>^0UT 1 '^"F'‘4-0. 854492 j. S‘5^*OUT2*':"F’4 

1 64 



i INC 

;l..UDE TWO INST HERE TO SET BJ'i" p. 

1 65 

S 7 

F'DDADF 

L..DA 

BITE) KP5i LOl, CND7' 

:!. 66 

88 

74D2F-F 

L/lJt-'i 

BTFE, KPO, CNDS 

1 67 



i CONT I. IMUE F I LTEF< I. MG 

168 

Ei9 

4450SB 

SUB 

OUT O^H-' 4 ; 0UT2-=rP4 , R 1 3 

;L 6'?> 




i GU 1 i . 033264 1 6i'i*0UT0‘':3-"’4"t"0. 6457900S*i^0iJT 1 8546 i425*5^0UT2*^rF'4 

;170 

90 

4C5SED 

ADD 

0UT0*‘r‘F-’4 } I M0-*rF‘4 1 ROG 

171 




f UU 1 u-«:“'p4— 1 . 033264 1 6”X-0U TO-^i-F' 4"^"0. 64579008 '^h3UT 1 SS546 1 4!25‘K'0UT2-'‘>P4’^“ 1 

172 



0UT2''i-P5 EQU TEMP 

173 

91 

40i301:::‘l“‘ 

L.DA 

0UT2-H-P5, 0UTl-i-P5, ROO 

174 




^ 0UT2-‘^‘P5-:i . OOOOOOOO-^'OU'T' 1 •^••F-‘5 

r7'3 

cy V 

4089i:::F 

LIlA 

0UT1<"P5, 0UT0-:-P5» ROO 

176 




i 0UTl 'r-P5--l. OOOOOOOO^h3UTO--P5 

J. / / 

‘”*1 

403 1 1 C 

ADD 

0UT0-:-P5, 0UTl e-P5, ROl 

1 78 




? OUTO'^PS^l, OOOOOOOO’^OU T0'*i"P5“V'0. 50000000*^*01) Tl'^-P5 

179 

94 

4089 IB 

SUB 

0UT0-rP5, 0UT0"-:-P5» R09 

180 




; 0UT0<-P5=--0. 99i3046S7-S"0UT O-'rPS+O. 49902343-iS'OUT 1 ■(•■PS 

181 

95 

408 1 5C 

ADD 

OUTO’^-PS, OUTl '^PS; R03 

1 82 




i 0UTO'(-P5=--O. 998046S7*0U"Or>‘rF‘5-i-0. 62402343*0UTl^t-F“5 

183 

’?6 

4089BC 

ADD 

0UT0(rP5, OUTO-v-PS, R06 

184 




i 0UT0-'rP5==l. 01364l35*0UT0-i-P5+0. 633773S2'S'0UTl->H-'5 

1 85 

97 

400 IF B 

SUB 

0UT0-H-'5, 0UT2-rP5. ROO 

1 86 




i 0UT0'«-P5= 1 . 0 1 364 1 35*0UT0'«^'P5-i-0. 63377382-5^0UT 1 (-P5--- 1 . 00000000*OUT2'^P5 

1 87 

98 

400 1 5C 

ADD 

OUTO-'^-PS/ 0UT2'‘:-P5j R03 

188 




i 0UT0-(-P5“ 1.0 1 364 1 35-»0UT0-'rP5-i-0. 633773S2-S-0UT 1 -rP5-0. S7500000-»0UT2'(-P5 

1 89 

99 

400 1 BC 

ADD 

0UT0*«:*P5; 0UT2**rP5, R06 

1 90 




i 0UT0-'r-P5“ 1 . 0 1 36-4 1 35•■^^■0l...iT0•'^■F'5•^•0. 633'7738;7i-»0UT 1 ■'i-F-‘5--0. i359:37500*0UT2'’j-P5 

191 

1 

4001 FC 

ADD 

0UT0‘'^'F’*‘5 ^ 0UT2‘‘i“P56 F-’^OS 

1 92 




i 0UT0*‘i**F*'5-L 01364135*^0UT0*‘rF'5-i“0. 63377382*^0UTl'*i"P5*”**0. S5546875*5^'0UT2‘^-P5 

1 93 

101 

4001 3D 

ADD 

OUTO-i-PS, 0UT2-V-P5. RIO 

194 




^ 0UT0*‘i“P5--l, 01364135*^0UT0*':**P5“^“0. 63377382-5^01)1 854492 1S'5^0UT2**^P5 

195 

102 

400 1 9B 

SUB 

OUTO''K-’5, 0UT2^'i-P5, R13 

196 




; 0UT0-H-P5"~ 1 . 0 1 364 1 35-k-0UT0'H--'5-i-0. 63377382’3-j:;!UT 1 -("PS-O. 8546 1 425-sOUT2(-P5 

197 

1 03 

4!309FD 

ADD 

0UT0*^'P5i IM0**rP5. ROO 

198 




i 0UT0'>:-P5-”l. 01364 135-5^0UT0(-P5 -h:i. 63377382^s0UTl >:-P5~-0. S5461425-»0UT2'6P5+ 1 

1 99 

1 04 

460 lEF 

LDA 

OUTPUT, 0UT0^("P0 

200 

105 

4lrI09EB 

SUB 

OUTPUT, OLITO-e-Pi 

201 

106 

4429ED 

ADD 

OUTPUT, 0UT0-("P2 

202 

107 

4C21EE 

SUB 

OUTPUT, 0iJT0-e-P3 

203 

108 

4E21ED 

ADD 

OUTPUT, 0UT0''"-P4 

204 

109 

44S9EB 

SUB 

OUTPUT, 0UT0-«“P5 

205 

110 

468 1 AD 

ADD 

OUTPUT, OUTPUT, L02 

206 

1 1 1 

468 IOC 

ADD 

OUTPUT, OUTPUT, ROl 

207 

112 

42C4EF 

LDA 

DAR, OUTPUT . 

208 

113 

4000EF 

NOP 


209 

1 14 

4483FF 

LDA 

NEOVAL, KPO ; PEAK DETECTION AND RUN DOWN SECTION 

210 

115 

7C8BDF 

LDA 

NEGVAL, KPS, LOl, CNDS 

i. 1 

116 

4280E7 

ABS 

TEMP, OUTPUT 

212 

117 

408A0A 

SUB 

TEMP, KPl, F<01 i TO SET A THRESHOLD 

213 

118 

4044E5 

LXM 

DAR, TEMP 

214 

119 

4000EF 

NOP 




. 1 . 


r*s 5;;:. v i. . U 




i: NE 

LC.iC. 

OBJECT SOUF 

ICE. STATEMENT 

2 1 5 

1 20 

74S3EF LDA 

OUTF'UT, KPO, CMOS 

2 1 6 

121 

4!,X91E7 ABS 

CEE. OUTPUT 

.id i / 

122 

4A91FT"' L...DA 

SAVE. BEE 

2 1 £5 

1 23 

4E‘79EB SOB 

; R Y E 

219 

124 

4AC4E5 LIM 

lJRh6 bEE 

220 

X 2S:i 

70C3EF’ LDA 

Fi.,..AG. KPO. CNDS 

fU** J- 

J. , 1 '.. 

F3C3EF LDA 

FLAG, i<P2. CND7 

•'7 •" r *’‘V 

127 

4C99EF I....DA 

BEE, SAVE 

2!id’.::» 

128 

4C9iEB SUB 

BEE; ijEE 

224 

1 

4AC4E5 1...1M 

BAR, BEE 

all* 

130 

F3C;3ED ADD 

hEHUj* Kl“'’.«d? LNIJ/ 

226 

;l,3l 

40C.3FF LDA 

PEAK. KPO 

J. .»:i. / 

132 

40E4EF LDA 

DAFO FT.... AG 

22 s 

i 353 

400 OEF NOP 


•’;v •".> C) 

1 3-^i- 

F9i:;9FF LDA 

F’EAK. SAVE, CND7 

230 

135 

4C91EF LDA 

BEE, CEE 

23 1 


4C99FI-" LDA 

AYE, SAVE 

4d';.:»2 

137 

42CCEF LDA 

DAF6 NEGVAL 

6 6' 

13S 

44C3EF LDA 

NPEAK, KPO 

234 

1 39 

44E9FF LDA 

PPEAK, PEAK 

-“•/ 0 

140 

FSCSFF LDA 

PPEAK, KPO, C.ND7 

236 

141 

F5E9EF' LDA 

NPEAK, PEAK, CND7 

.iT« / 

i 42 

4264EF L.DA 

.UF-iF‘‘ ? i:j .1 1 A 

233 

143 

4000EEF NOP 


'■7 • 7 .} c> 

144 

F5C3FF LDA 

PPEAK, KPO, C;ND7 

240 

145 

4A6CEF L.DA 

Drk# B .[ i B 

241 

146 

4000EF NOF’ 


242 

147 

F5C3EF LDA 

NPEAK, KPO, CND7 

243 

148 

48F9EF L.DA 

PSTORE, PCRDV 

244 

149 

42F9FB SUB 

PCRDV, PPEAK 

245 

1 50 

48ECE5 LIM 

DAR, PCRDV 

246 

151 

4EFBEF LDA 

PINFO, KMi 

247 

152 

76F9FF LDA 

POSPK, PPEAK, CNDS 

248 

153 

7EDBCF i...DA 

PINFO, 1<P7, LOl, CNDi 

249 

154 

4AE4E5 LIM 

DAR, PINFO 

250 

155 

4SF1FF LDA 

PCRDV, PSTORE 

25 1 

156 

FBF9FF LDA 

PCRDV, POSPK, CND7 

252 

157 

SOOOEF OUTt 

5 

.d •«* 2j 

158 

SOOCiEF" OUTO 

254 

159 

8000EF OUTO 

255 

160 

8 OOOEF OiJTO 

256 

161 

800EEF" LDA 

H S 1 0 R E } N C R D V 1 0 U i 0 

257 

162 

82A4FB SUB 

NCRDV, NPEAK, OUTO 

.td c* 

163 

404EE5 LIM 

DAR, NCRDV 

259 

164 

4EAEEF LDA 

NINFO, KMI 

260 

1 65 

76A4FF LDA 

NEGPK, NPEAK, CNDS 

26 1. 

166 

7E8ECF LDA 

NINFO, KP7, LOl, CND: 

'y /-■'”/ 

«!*«• \Mi^ «l*«l 

167 

4246E5 LIM 

DAR, NINFO 

26’'."! 

168 

4006FF LDA 

NCRDV, NSTORE 

2.64 

169 

F30EFF LDA 

NCRDV, NEGPK, CND7 

265 

170 

AOOOEF 0UT2 

266 

171 

AOOOEF OUT': 

id 

267 

172 

AOOOEF 0UT2 

268 

173 

AOOOEF 0UT2 


.i .1. 



BIT A 

10 

0UT2''rP3 

0 

0LITJ.-<-F-3 

U 

OUTO-rPS 

12 

0IJT2'«-P4 

0 

0UTl'i-P4 

13 

0UT0-«“P4 

14 

BITB 

15 

CiUT2+:-P5 

0 

OUT3.<"P5 

1& 

0LIT0-e-P5 

17 

OUTPUT 

IS 


F'AGE 


MEGyAl. 



FLAG 

PEAK 

iMPEAK 

PF‘E'.Ai< 

PSTORE 

PCRDV 

PliMFO 

POSPF-. 

SMS"rOF<E 

MCRDV 

MINFO 

MEGPK 


MY 


20 

i. 




36 

37 


A S S E M B L. Y C 0 M P I... E T E 

f.n.F;F<OIRS — 0 

W A R N I. N G 3 = 0 

RAMSIZE = 38 


APPENDIX C 



SEiiBLEIR, 


MODUL. 


DC OE.J 


S 0 U R C E S "f A T E M IE N 1" 


-S •& -S- -a ■Sr -S- ■& * -K- ■5!' ■& ■& * * •& -H- -SC- -ii •& # -S- -S •& * -K- •& -i?- ■i"r ■* -S- -S -S- # •& -K- ■H -Sr -ft -S- -fr -fi- •!:: ■» * -Sr -S- -S -S- -S -S ■& -S- -S- -S ---r * ■& -S- -S' -S- -S- -fr -Sr -'ft -Sr ■& -ft -Si -?r -i^ -S -S 

PROGRAM F'OR F-IKlAL COMF'Lrf A'TXOhi OF- THE PTT'CH PERIOD 

■ii- -» * * -fi- -S- * -ft * •& * * * ■& ■■«■ * -Sr •& -S- -R- -S- -S- -S- •■?■• -fr -R- R' -f r * * ^ R R R * R •»■»**••* R R R R R * * * ■» * -& •» R R -S- R- -S- -S- R * R * R- -S- Rr •» R- R- R R- R- R R- 

’THIS PROGRAM IS USED FOR THE FINAL. COMRUTATIOIM OF THE PITCH PERIOD 
OF THE i-=ARALL.EL PROCESSING PITCH PERIOD ESTIMATOR. 

THE HAIM PROGRAM IS USED TO SET ■THE INTERRUPT MASK AND DISPLAY THE FITCH 
PERIOD COMPUTED ONTO T’HE WOIRK-STATION SCREEN. 

THE ISS IS INVOKED EACH. TIME A RST 7. 5 INTERRUPT IS RECEIVED. IT IS ESSENT 
-lALLY BROKEN INTO TNO PARTS, EACH PART EXECUTED ON ALTERNATE INTERRUPTS. 

THE FIRST PART: 

THIS PART INITIALISES THE TABLE TO OFFH IN ALL LOCATIONS. THE READ 
COUNTER VIZ "CTRD'-' IS SE'T TO ;i. SO THAT NEXT TIME AROUND TRIE INTERRUPT IS 
SERVICED BY THE SECDDND PAR’l". •'PriE RESET STATI.,!S IS CHECKED IN THE “RSTWRD" 

AND APPROPRIATE LOCATIONS ARE ACCORDINGLY FILLED. 

THE SECOND PART; 

IN THIS PART THE LATEST ESTIMATES OF THE PITCH PERIOD ARE ACQUIRED 
AND TI-IE TABLE IS COMPL..ETED. Ti~!EN THE PROCESSING IS PERFORMED TO ELECT THE 
MOST POPULAR CANDIDATE , FROM THE LATEST FOUR ESTIMATES. THE CRITERIA TO 
BE'£ S'ATISFIEEi ARE: 

a) A CANDIDATE POLLS AT LEAST FOUR VOTES BASED ON THE INEQUALITY 
iPC-pi !<;i./8 PI. 

b) NOT MORE THAN ONE CANDIDATE INDICATES A RESET HAD DCCURED 
IN THE CURRENT ESTIMATE, INDICATING, THAT A PERIOD IN EXCESS OF 16 

; MIi,...LISECONDS HAS OCCLiRED. 

1 FAILING THE ABOVE TESTS, A 'M-IISS” DECISION IS MADE. ELSE THE PITCH 

: PERIOD APPEARS ON THE WORKSTATION SCREEN, UNDER CONTROL. OF THE MAIN PROGRAM. 




29 

30 


•K- •& * -s -a * * •» -a * * ■& * •& * 

M A I N F** F? G F’' A I i 

4000 


31 


ORG 4000H 


4000 

3E1B 



MVI A, IBH 


4002 

30 

34 


SIM 


4uOS 

21 1S40 

35 


LXI H, ISS75 

4006 

4:f.2 1 '"''bh'* 

36 


SHI..D 5819H 


4009 

3iEC3 

37 


MVI A, 0C3H 


400E 

321S5S 

38 


£FTA CiiSlSiH 


400IS 

3E00 

39 


MVI A, OOH 


4010 

320C50 

40 


ST A CTRD 

, INITIALISE READ COUNTER 

4013 

i-"B 

41 


El ■ 

, THIS PREPARES THE PROGRAM FOR RST7. 5 

4014 

00 

42 

WASTE; 

NOP 


4015 

031440 

43 


UMP WASTE 

i WASTE TIME TILL NEXT INTERlRUPT ARRIVES 



44 






45 

i 





46 



S ***-K--S***-**’S****«-S**«*-SJ****«****-!«--«-***-K-**^S-'ft« 



47 

# 



40 IS 

F5 

48 

I3S75: 

PUSH PSW 


40 1 9 

C.5 

49 


PUSH B 


401 A 

DS 

50 


PUSH D 


40 IB 

E5 

51 


PUSH H 


401 C 

3A0C50 



LDA CTRD 


401 F 

FEOl 

53 


CPI 01 H 

i GO TO SECOND PAF<T AT 2 nd FUST?. 5 

402 1 

CA7840 

54 


UZ READ2 



PAGE 


IS -I : 

. 3 \} 3 L> 7 3 i ,•* 3 

tiACFlO 

ASSENB 

i....ERf V4. 1 

M!...sLiU1....E F-'AGE 2 

LOC 

OB...I 

LINE 


S 0 U C E S T A T IE M t: 

;nt 

4024 

DA2740 

55 

Ft A 


«.JC 1 

; SERVICE FIRST PART AT IstRSTT. 5 



57 

} 



40 27 

SiEO 1 

58 

HEAiij 1 : 

NO I. A.OIH 


4029 

320 C50 



STA CTRD 

i SET READ COUNTER TO 1 

4020 

2 1 CM.) 50 

fhO 


L-X I H; 500 OH 


402F 

3EFF 

61 

I NIT; 

HVl A, OFFH 


403 1 

'7 7 



f*lLJV I'l ^ H 


4032 

20 

63 


I NR 1.... 


4033 

3E0C 

64 


MV I fh OCH 


4035 

AD 

65 


aKA L 


4036 

U2;2F40 

6*6 

67' 

; 

JNZ I. NIT 

:> f) L„ L„ 1 fi B i.„ tl L.. 0 C A T 1 0 N S S E T "T 0 0 F~ F hi 

4039 

DEOO 

69 

J 

CONTIN 

IN FIVE 


40 3 B 

E6AA 

70 


AN I OAAH 


4031.1 

320E50 

7 :l 


STA RSTWRD 

i RESET STATUS IS OBTAINED 

4040 

E602 

72 


AN I 02H 

i TEST FOR A RESET 

4042 

C24A40 

73 


JNZ FIL.L22 

i DO NOT BOTHER TO READ IF RESET 

4045 

DB80 

74 


IN ONE 


4047 

32C! 1. 50 



STA F'i2 

.i IF NO RESET READ IN PITCFi OF ONE 

404A 

3A0E50 

76 

F 1 2 <i«. 

LDA RSTWRD 


404D 

E620 

77 


AN I 20H' 


40 4F 

C2.3740 

78 


JNZ FILL32 


4052 

DBAO 

*79 


IN TWO 


4054 

320450 

80 


STAi P22. 

i READ I N TWO 

4057 

3AC>lr.:.50 

81 

F I LL32 

: LDA RS'VWRD 


40 5 A 

E680 

82 


AN I 80H 


405l.- 

C.' .cl 6 4 4 O 

1**1 * *1 


JNZ FILL42 


40 5F' 

DECO 

84 


IN THREE 


406 1 

320750 

•rj5 


STA F:‘32 


4064 

3AOE50 

86 

F;i;LL42 

; LDA RSTWRD 


4067 

FI 608 

87 


AN I OSH 


40i5:-9 

C27 1 40 

88 


JNZ EXITl 


40 6C 

DB60 

39 


IN FOUR 


406E 

320A50 

90 


STA P42 




91 




407 ;l. 

El 

92 

• 

POP H 


93 

EX III : 


4072 

Dl 

94 


POP D 


4073 

Cl 

95 


POP B 


4074 

FI 

96 


POP PSW 


4075 

20 

97 


RIM 


4076 

FB 

98 


El 


40 '7 7 

C9 

99 


RET 




100 

f 





101 

f 





102 



SET30ND PAF;T 



103 






104 




4078 

3E00 

1 05 

READ2; 

MVl A< OOH 


407 A 

320C50 

106 


STA CTF® 

iRFISET F^EAD COUNTER FOR NEXT F^ST7 



107 




407D 

DBOO 

1 08 

HSTST; 

IN FIVE 


407F 

E6AA 

109 


ANI OAAH 




;is-i; 

! S080/S0«: 

i5 MACRO 

UjC 

OB..J 

LINE 

4053 :i. 

OF- 

1 10 

40S'2 

320E50 

1 ! ! 

4085 

0 1 CK)00 

112 

40S8 

OC 

!13 

4Ci89 

/ 

!!4 

408A 

/y 

115 

40&B 

EE05 

1 16 

408D 

CA9D40 

117 

40'P0 

7 A 

118 

409 ! 

1 / 

119 

4092 

17 

120 

4093 

DA 99 40 

121 

4096 

C:3S840 

122 

4.099 

04 

i. 

409 A 

11:388 4 cj 

124 

4-09 D 

3 EX) 2 

125 

40 9F 

I::'S 

126 

40 AO 

CAFi4! 

1 27 

40A'3 

DAFI4! 

1 28 



:l 29 



130 

40 A6 

2 !L 0 1 50 

131 

40A9 

3A0E50 

1 32 

■=10AC 

07 

133 

40 AD 

320E50 

134 

40B0 

E60'2 

135 

40 B2 

C2C 1 40 

136 

40B5 

DBSO 

137 

40B7 

320050 

1 38 

4013A 

86 

1 3’9 

40BB 

DAC140 

1 40 

4oee; 

3'2.0'2'-:50 

141 

40C! 

2 1 0450 

142 

40C4 

3A0E50 

143 

40C'7 

E620 

144 

^L0C9 

C2D840 

145 

40CC 

DEAO 

146 

40CE 

3'20350 

147 

40 'D 1 

86 

148 

40D'2 

DAD840 

i4S 

40D5 

3:20550 

150 

40DS 

'2 ! 075i0 

151 

401DB 

3A0E50 

15:2 

40 DE 

E680 

153 

40E0 

C2EF40 

154 

40E3 

DBCO 

1 5i5‘ 

40 IE 5 

320650 

156 

40E8 

86 

157 

401E9 

DAEF40 

158 

40EC. 

32.0850 

15-? 

40EF 

210A50 

160 

40F2 

3A0E50 

161 

40F5 

£608 

162 

40F"7 

C20641 

163 

4oF A 

DB60 

164 


ASSEMEiLEF^ V'4. 1 


MOiJULE PAGE 


SOURCE STATEHEIMT 


RR>-- ; CATERS FACR SUBSEQUENT RAL- S 

S i A RSTWREi 
LX I B) OOOOH 

iRPT : INR C 

MOV D, A 
i-'IOV A, C 
XRI OSH 
...iZ LEAVE 
MOV A.. D 
RAL 
RAL 

JC COUIMT 
JMP RPT 

COUNT: :tMR E 

JMP RPT 

LEAVE: MV I A. 02H 

CMP B 
JZ HISS 
...iC HISS 


f 

ROWSRD: LXl H, P;12 
L.BA RSTWRD 

RLC i TO UNDO LAST RRC IN HSTST 

STA RSTWRD 
AN I 02H 
JNZ FILL2I 
. IN ONE 
STA Pil 
ADD M 
JL i“ lLLj:t i. 

STA P13 i 1ST AND 3RD ROW VALUES ARE 

FILL21: LX I l■LP22 
LDA RSTWRD 
AN I 20H 
JNZ FILLS'! 

IN TWO 
STA P21 
ADD ii 
JC FILL31 
STA P23 

FILLS!: LX I H, P'32 
LDA RSTWRD 
ANI SOH 
JNZ FILL41 
IN THREE 
STA P31 , 

ADD M 
JC FILL4i 
STA P33 

FILL41: LXl 1-LF*42 
LDA RSTWRD 
ANI OSH 
JNZ PRESET 
IN FOUR 


FILLED 



SIS--.1 

C 8080/8085 

HACF<0 ASSEi'-'lBL.ER.* 04. 1 

MODULE PAGE 4 

I...OC,; 

OE...J 

LINE 

SOURCE STA'TENE 

;nt 

40FC 

320950 

165 

ST A F'41 


40FF 


166 

ADD H 


4100 

DA0641 

:l 67 

Jl.. F \ 


4103 

320Bi50 

1 d.S 

Sn"A P43 


4 1 06 

1E05 

169 PRESET; 

MV I E.* 05H 


-^•1- 1. 08 

31"C)0 

170 

MV I A.* OOH 


4100 

320F50 

171 

ST A CTRPll 


4 3. OD 

32. 1 050 

172 

STA CTRP21 


41 10 

321 150 

:l 73 

ST A CTRP31 


4113 

1 250 

174 

175 ; 

176 ; 

STA CTRP41 


4116 

ID 

177 SELECT; 

DOR E 


41 17 

CAA64 1 

178 

•JZ COMPAR 


‘■1 1 1 f'“l 

7B 

179 

MOV A. E 


41 IB 

FEOl 

180 

CPI OlH 


41 ID 

CA2F4 1 

181 

..JZ VOTE! 


4 1 20 

FE02 

182 

CPI 02H 


/.j, ’i ''2 

C.A3C41 

183 

..JZ V0TE2 


4125 

FE03 

184 

CPI 03H 


4127 

CA4241 

185 

..JZ VOTES 


4 1 2A 

h 

186 

CPI 04 H 


4 i 2C 

i;;:A484 1 

187 

188 : 

189 ; 

.JZ V0TE4 

; THE APPROPRIATE CANDIDATE IS CHOSEN 

412F 

3 AO 050 

190 VOTEl; 

LDA Pll 


4132 
4 1 3 '3 

47 

191 LOQPl; 

i QO 

I 'iUV E; l3 

r*« o r*‘ 

; STORE CANDIDATE IN F<EG B 

4134 

OF 

.1. /.t;.. 

HHC 


4135 

OF 

194 

RRC 


4 1 36 

E61F 

195 

AN I IFH 


4138 

57 

196 

MOV D, A 


4139 

C34E41 

197 

198 j 

i C) Cj 

...IMP ELECT 

i COMPUTE ONE EIGHTH OF PXX 

AND F4JT IT IN REG D 

4 1 30 

3A0350 

J. / / ; 

20U V'UlE'.,-i; 

LDA P2.1 


4i3F 

C3324 1 

20 1 

.JMP LOOP! 


4 1 42 

3Ai0650 

202 VOTES; 

LDA P31 


4145 

C3324 1 

203 

...IMF' LOOP 1 


4148 

3(A0950 

204 V0TE4; 

LDA P41 


414B 

C33241 

205 

206 ) 

207 5 

.JMP LOOP! 


414E 

210050 

208 ET-ECT; 

LXI H, 5000H 


4151 

7E 

20’9 LOOF'2 ; 

MOV A, M 


4152 

90 

210 

SUB B 

iREG B HOLDS VALUE OF PXX FROM LOOP 1 

4153 

DA6441 

nit** di jd» 

.JC NEGl'VE 

iFOR NEGATIVE RESULTS OF SUB OPERATION ; 

4156 

BA 

^7 1 O TpoT • 

CMP 0 


4157 

DA694 1 

213 

.JC SCOF^E 

i CY INDICATEIS D I FFCONE EIGHTH PXX 

4 ISA 

2 Ft 

214 SUBLP; 

I NX H 

iTO CHECK IF ALL TWELVE HAVE BEEN CHECKED 

41 5B 

3E0C 

215 

MV I A, OCH 


415D 

AD 

216 

XRA L 


415E 

UO 1 6*4 1 

217 

.JZ SELECT 

; TO POLL THE NEXT CANDIDATE 

4161 

0351 41 

218 

219 i 

.JMP L00P2 




;is--r 

! 8030/3085 

MACRO 

AiBSEMBL 

■ER, k. 

*4. 1 

MODULE:! F‘AG1E 5 

i OC 

OB’J 

LIME 


SOUFiC 

■■E STATE! 

lENT 



iZv 0 

i 




4164 

2F 

.Z.i’C j. 

NEGTVE: 

CHA 



4 1 65 

3C 

/ *’/■ “/ 


IMR 

A 


4166 

03564 1 



..IMP 

TES'T 




•ti-. “T 

.m, 5..,, 





4169 

7B 

!Z ,<:i 3 

SCORE : 

MOV 

A. E- 


41 6A 

FEOl 

227 


CPI 

OlH 


4 1 

i;;:A/E:.4 1 

■7 S”'. 


3 2 S 

:C0RE1 


4 1 6F 

f"E02 

229 


CPI 

02 H 


4 1 7 1 

CASEA '!- 1 

230 


1 i** 

0 A\. C 

:C0RE2 


4174 

FE03 

1 


CPI 

OSH 


4 1 76 

CA924 1 

232 


■..JZ E 

«0Ul“dri3 


41 79 

FE04’ 

233 


CPI 

04H 


41 7B 

CA9C:4 1 



JZ E 

;C0RE4 


417E; 

oAoF" 5^/ 

235 

SCORE 1 ; 

L.DA 

CTRPll 


4HS1 

3C!; 

236 


IMR 

A 


4- 1 '32 

3 OOF 5*0 

237' 


ST A 

CTRPl 1 


4 1 85 

C35A4 1 

0 Cl* 


.JMP 

S1.,IBLP 


4188 

3 A 1 050 

2.39 

SC0RE2; 

LDA 

CTRP21 


41 SB 

3C 

240 


IMR 

A 


:l. 'SC 

32 1 050 

241 


ST A 

CTRF '21 


418F 

C35A4 J. 

242 


.JMP 

SUBLP 


4192 

3A1 150 

243 

SCORES: 

LDA 

CTRP31 


4195 

3C 

244 


IMR 

'A 


4196 

321 150 

245 


S'TA 

CTRP31 


4 1 99 

C35A4 1 

246 


JMP 

SUBL.P 


419C 

3A1250 

247 

SC0RE4 : 

I..DA 

CTRP41 


419F 

3C 

248 


IMR 

A 


41 AO 

321250 

249 


'ST A 

CTRP41 


41 A3 

C35A4 1 

250 


JMP 

SUBL.P 

ALL 4 CTRS HAVE COINCIDEMi: 



251 

.« 






.vtl 

i 




1 A 6 

3A0F50 

"7FiPi 

COMPAR: 

LDA 

CTRPll 


41A9 

FE04 

254 


CPI 

04H 


4 1 AiB 

DAB541 

255 


•JC C 

;HKP2i 

i DO MOT BOTHER IF CTROT 

41AE 

47 

256 


MOV 

B> A 


41AF 

3A0050 

257 


LDA 

Pll 


'-I- 1 B 2 

320D50 

25*3 


STA 

DECSN 

; TENTATIVELY Pll^PERIOD 

4 IBS 

3A1050 

259 

CHKPZl ; 

LDA 

CTRP21 


4 1 B8 

FEU 4 

260 


CP I 

04H 


41 BA 

DAU‘S41 

261 


JC c 

:H1<P31 


4iBD 

.By 

!Z6‘2 


CMP 

E 


41 BE 

DAC841 

263 


JC C 

;HKP31 

i IF CTRP21<CTRP11 GO AHf 

41C1 

47 

264 


MOV 

A 

. 1 p CTRP2 1 >CTRP 1 1 THEN 

41C2 

3A0350 

265 


LDA 

P21 

i P21 BECOMES THE PERIOD 

4 ICS 

320D50 

.Z» 66 ‘ 


STA 

DECSN 


4 ICS 

3A1 150 

"■7 AT 

CHKP31 ; 

LDA 

CTRP31 


41CB 

FE04 

26<8 


CPI 

04 H 


41 CD 

DADB41 

26‘? 


.JC c 

:.HKP41 


41 DO 

B8 

270 


CMP 

B 


4101 

DADB41 

271 


JC C 

;:HKP41 


41D4 

47 



MOV 

B. A 


4 IDS 

3SA0650 

273 


I..DA 

P31 


4 IDS 

320D50 

274 


STA 

DECSN 



SCORE! 



F'hGE 


6 


W i U / t..J OO j-'l i ,.:hi, j 


i,j:::ic 

OiB..,.! 

LINE 

4IDB 

3 A 1 250 

275 

4 IDE 

FE04 

:27 c. 

4 1 iSO 

DAi-" 1 -I- 1 

2 ^ *7 

1 E3 

BS 

:278 

41E4. 

DA 1342 

'A /9 

41E7 

4 '7 

280 

4 i £8 

3A095 0 

,i:» 1 

41EB 

320D50 


4 1 EE 

C3F94 .1. 

284 

4 1 F i 

3EFF 

',7 (b 

4 1 f3 

320350 


4.1!-.;::. 

C3F941 

289 

290 

4 i F9 

3A0D50 

29 1 

4iF’C 

EEFF 

292 

4 IFF 

I7A0D42 

29: *5 

4201 

3A0D50 

294 

42i:*-4- 

CDBD03 

:295 

'^1-207 

CDC402 

296 

420A 

C3 1 342 

297 

420D 

010049 

298 

42 ]. 0 

CDS:804 

299 

4213 

El 

300 

42 1 4 

Di 

30 1 

4215 

Cl 

302 

42 1 6 

f 1 

303 

4217 

20 

304 

4218 

FB 

3Cj5 

42 1 9 

C9 

30 1,* 

307 

308 

309 

1 6D 1 


310 

500 D 


31 1 

03BD 


312 

02C4 


3 1 3 

0438 


314 

500i'£ 


315 

50 OF 


316 

50 1 0 


c»i 7 

501 1 


3 1 8 

50 1 2 


3 1 9 

0080 


320 

OOAO 


32 1 

OOCO 



0060 


323 

0000 


324 

500 C 


325 

5000 



500 1 


327 

5002 


328 

5003 


329 


ASSEMEi,..ER, G4. i 


SOURCE STATEMEiMT 

CHi<P'4;i. : LDA Cl”RF"'-iM 
CF-‘ I 04H 

CMP B 
JC' EXIT 
MOV B, A 
l...,DA P41 
ST A DECSN 
...JMP RIESUITT 


HISS: MV I Ai OF’FH 

STA DECSN 
...IMP RESl..ii,..T 


) 

F<ESULT: LDA DECSN 
XRI OFFH 
...IZ NOISE 
I..DA DECSN 
CALL BIHEX 

i:;al.l, twosp 

•JMP EXIT 

NOISE: LX I B, 4900H 

C:;Ai..L PNTMS 
EXIT: POP H 

l=‘OP D 
POP B 
POP PSW 
RIM 
El 
RE'T 


f 

DELAY EQU 16D;l.H 
DECSN EQI..i 500DH 
El HEX EQU 03EDH 
TWOSP EQU 02C:4H 
PNTMS EQU 0438H 
RSTWRD EQU 500EH 
CTRPll EQU 500FH 
i:.:TRP2 1 EQU 50 i OH 
CTRP3:l, EQU 501 IH 
i;;:TRP41 EQU 5012H 
ONE EQU 80H 
TWO EQU OAOH 
THREE EQU OCOH 
F’OUR EQU 80H 
FIVE EQU OOH 
CTRD EQU 500CH 
Pll EQU 5000H 
PI 2 EQU PlH-1 
P13 EQU Pi 2+1 
P21 EQU PI 3+1 


MODUI..E 


; IF NONE P0LLS>4 VOTES A HISS DECISION 


:• DE:T:;SN now HOLDS POPULAR 


PER I OD 




1 S I I 8 0 Si /’ Si 0 i:::i 

MACRO 

assemble 

P-' V4. :i. MODULE 

1.01; CiBlJ 

LINE 

s 

OURCE S'TATEMENT 

5004 

330 

F'22 EQO 

P2 3 , 4- 1 

5005 

33 i 

P23 EQU 

P224-;|. 

5006 

332 

P31 EQU 

P23+i 

5 / 

•.!> 

F'32 EQU 

P31-H. 

500S 

334 

P33 EQU 

P32+i 

5009 

33!5 

F'41 EQU 

P334- 1 

500A 

3256 

P42 EQU 

P4 1 + 1 

500 B 


f■■'43 EFJU 

P42-M. 


338 

END 



PUBl,.IC S^'MBOLS. 

EXTEn-<NAL SYMBOLS 

USEF< SYMBOLS 


BIHEX 

A 

03ED 

CHKP2 3. 

A 

4 IBS 

C.HKP31 

A 

4iCS 

C.Hi<P4 1 

A 

4 IBB 

COi'iPAF< 

A 

43.A6 

corn" IM 

A 

4039 

COUNT 

A 

4099 

CllYD 

A 

‘■50 OC 

CTRP3,3. 


500F' 

C"I"RP21 

A 

‘•50 3. 0 

CT'RF‘3'1 

A 

50;l.i 

CTRP4:l 

A 

50:1:2 

DECSN 

A 

5000 

DELAY 

A 

16Di 

EL.ECT 

A 

4. 3. 4E 

EX IT 

A 

4 .»:« 1 •.«' 

EXIT! 

A 

407 1 

FILL.2;l. 

A 

40C 1 

FILL 2 2 

A 

40 4 A 

FILL31 

hh 

40DS 

FILL32 

A 

4057 

FH i,41 

A 

40EF 

FIL.L42 

A 

4064 

F I VE 

A 

0000 

FOUR 

A 

0060 

HISS 

A 

41 FI 

HSTST 

A 

4070 

IN IT 

At 

402F 

ISS75 

A 

•4'0 J. 8 

LEAVE 

A 

409 D 

LOOP 1. 

A 

43.32 

L00P2 

A 

43.53. 

NEGTVE 

A 

4164 

\-iO I SE 

H 

4200 

ONE 

{A 

0080- 

p;l;i 

A 

5000 

PI 2 

A 

Si 00 1 

PI 3 

A 

500:2 

P2.:l 

A 

5003 

P22 

r‘{ 

5004 

P2.3 

A 

5005 

P31 

A 

St006 

P32 

A 

■5007 

F‘33 

A 

50 OS 

P4 3. 

A 

5009 

P42 

A 

500 A 

P43 

iA 

500E 

PNTMS 

A 

043S 

PRESET 

A 

4106 

READl 

A 

4027 

RE.AD2 

A 

4078 

RESULT 

A 

4;I.F9 

R0W3RD 

A 

40A6 

RF-T 

A 

40SS 

RSTWRD 

A 

500E 

SCORE 

A 

4169 

SCORE 1 

A 

417E 

SC0RE2 

A 

4 J. 8 £5 

SC0F:£3 

A 

43.92 

SC0RE4 

A 

4 3. 9C 

SELECT 


4116 

SUBLP 

A 

415A 

TEST 

{A 

4156 

THREE 

WASTE 

A 

A 

00 CO 

40 3.4 

TWO 

A 

00 AO 

TWOSP 

A 

02.C4 

VOTEl 

A 

412F 

VCTi"E.2 

A 

4:i3C 

VOTES 

A 

4142. 

V0TE4 

A 

4148 
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APP'3NDIX D 

2920 SIGNAL PROCESSOR 


The 2 9 20 Signal Processor is a single chip micro- 
computer designed especially to process real time analog 
signals. It has on board program memory, scratchpad memory, 
D/A circuitry, A/D circuitry, digital processor, and I/O 
circuitry. Its capabilities in signal processing are diverse 
and powerful, and include an extremely broad range of appli- 
cations as listed in Table D^l. 

The pin out and the 2920 block diagram are in Figures 
D.l and D.2 respectively. A list of Memory-ALU Instruction 
Opcodes is in Table D,2. The program meraoiry consists of 
192, 24 bit words. The fields allocated in one such instruc- 
tion word are ALU, destination, SOURCE, SCALER CODE, ANALOG. 
This perroits simultaneoxis digital and analog, processing in 
the IC. 


D- 1 ANALOG OPE RATI ON S 

Under program control, one input may be selected 
from four possible inputs, and the signal sampltid and held. 

The signal would then be converted to a digital word with 
up to 9 bits of linear conversion (sign bit and 8 amplitude 
bits). The bits are formed by a successive approximation 
A/D conversion and stored in the Digital Analog Register 

I 

(DAR) . The DAR is a register for interface between the 

analog and digital sections of the 2920. During A/D conversion. 



D.2 


the DAR accumulates each bit of the digital word until 
conversion is complete. This word may then be leaded into 
the scratch pad RAM for further processing. 

The input signal is sampled by a sequence of IN 
instructions, the number depending on the clock rate and the 
valxte of the external S and H capacitor. Then a seqxjence of 
conversion instructions are xised to obtain each bit in turn. 
Lesser IN instr\jctions are needed to sample a digital input 
level. 

D-2 DIGITAL OPERATIONS 

The digital part of the 2920 will be operating 
simultaneously with the above analog operations. For 
example, during a 9 bit A/D conversion, a 3-Pole low pass 
filter could be realised using the digital circuitry. The 
digital loop includes a 2 port addressable 40 word RAM, a 
binary shifter, and the ALU. Under program control, two 
25 bit locations in RAM are simultaneously addressed, with 

data fran the A address passing through the binary shifter. 

2 -13 

This shifter allows scaling from 2 to 2 . The scaled 

A value and the unsealed B value are then propagated to the 
ALU as operands. The ALU operates on these values with 
digital instructions specified by the program. The 25 bit 
result of that operation is loaded into the B address loca- 
tion of the RAM. The entire set of actions (analog operation, 
dual memoa:^ fetch, binary shift, ALU execution and write 
back: to RAM) take place in one instruction time. 
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D-3 PROGRAM LENGTH AND INSTRUCTION TIME 

The EPROM can hold 192 instructions for sequential 
execution only. The program control goes back to the first 
instruction automatically at the end of the program which 
may be 192 instructions long, shorter programs have to be 
terminated with an EOP instruction. 

The instruction time is calculated frcm the expre- 
ssion 

T^„„. = 4 X i where f = clock; frequency to 

^ ■ the 2 9 20. 

Therefore, the time for one pass through the 

program is given by 

Tprog = N X 4 X ^ where N = program length. 

D-4 SAMPLING RATE 

In the above context it is pointed out that the 

sampling rate to sample the input analog signals is decided 

by the T . If an inpat is sampled only once during one 
prog 

progpram pass then the sampling frequency is given by 

f = — 

^ "^prog 

However, the sampling rate can be increased by sampling 
the input more than once during a program pass. 

D-5 CONSTANT ARRAY 

The constant array consists of 16 psuedo-locations 
in. the RAM address field. These constants are accessed only 
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from pox-t A, i.e. only as a source operand. Each unsealed 
constant is a multiple of one-eighth/ from -8/8, -7,/8 ... 
to +6/8, +7/8. By passing these constants through the 
scaler, actually a much larger range of constants are avail- 
able. 

D-6 REFERENCE VOLTAGE 

A positive reference voltage has to be provided by 
the user. The range of acceptable voltages is from +1 to 
+2 V and is chosen to suit the application. The input and 
output voltage range is limited to the range of the VREF. 

The D/A is a multiplying type and the step size (iLSB), is 
computed as VREF/256. Noise appearing pn the VREF pin will 
be transferred directly to the input and output signals 
through the D/A. VREF must therefore be noise free. 

If digital level signals are to be input or output, 
the VREF must be greater than +1.5 V. 

D-7 INPUTS AND OUTPUTS 

The four multiplexed inputs use the same S and H 
capacitor. As a result the S and H capacitor is to be 
chosen carefully and the number of instruction necessary 
to acquire a sample value should be properly adjusted. The 
guide lines are as follows: 

(a) The S and H circuit impedence is 1.5 K-ohm. 

For a given C between 100 and 1000 pf we have the RC value. 
Then use enough IN instr\JCtions so that the time for sampling 



the input is at least six times this RC, for a 9 hit res®lu- 
tio 0 during h/D conversion, 

(b) If the instruction time exceeds 600 ras^ as in 
the present implementation, then a 1000 pf ca^^citor is 
required for S and H. 

(c) However, if during the program execution, it 

becomes necessary to sample all four inputs, then a larger 
number of IN instructions must be used per input to keep 
down the cross talk' levels. Sometimes, there is no scope 
of using a large number of IN instructions due to program 
memory restrictions. In such cases, a dummy read can be 
performed on an input pin that has been grounded (or put at 
a negative voltage equal to as in this case) to dis- 

charge the S and H capacitor prior to reading the desired 
input, 

(d) If the input being read holds only logic levels, 
then a fewer nirtber of IN instructions and CVT instructions 
are required to acquire enough of the input signal to make 

a decision on the logic level. This feature w'ill permit 

digital inputs to the 2920. 

The input A/D scheme of the Processor (Figure D.3) 
and the fact that the processor \ises Two's complement 
arithmetic, cause a peculiar problem when low frequency 
sinusoids or positive going signals are being read. The 
problem is that the value after a positive peak value is 
read as a zero and this can be avoided by adding a small 
negative constant to the DA.R during A/d conversion, as shown 
done in Appendix C. 
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To put out a signal from the Processor, the desired 
value is placed in the DA.R, allowed time to settle and then 
a number of OUT instructions are executed to allow the output 
to settle. The eight output pins can all be used as analog 
or digital outputs or as 5 S.rt analog part digital depending 
on the voltage levels at the mode pins and M 2 (Table D,3). 

Analog output is done as above. The output signal 
level is determined by the The only requirement is 

that enough OUT instructions should be used to let the 
output signal value settle. Also while output is going on, 
the DAR should not be used for any operations. 

Digital outputs are made by the following method: 

a) The V ^ should be >+1.5 V. 

ref 

b) The LIM instruction is used to present a logical one 

or zero to the DAR for output. Then the usual sequence 
■ of OUT instructions are employed. 

c) An external pull up resistor to +5 V is to be used at 
the output pin to enable it to drive TTL logic, 

TTL Logic levels that are to be input to the 2920 
SIGIN pins must be reduced to the limit by use of a 

voltage divider. 

D-8 other useful OUTPUTS 

By using 10 K pull up resistors to at the 

CCLK, RST/EOP, OP the signals at these pins can be put to 
Several iises, e.g. cascading 2920’ s, digital input and out- 
put both parallel and serial etc, E21]. 
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In the current implementation, the CCLK output was 
used to provide a trigger to the XR 2240 timer generating 
the interrupts, 

CCLK is an output clock at 1/16 the frequency of the 
2920 clock input. 

OF is ah output that occurs whenever an overflow 
occurs in the execution of the program. 

EOF indicates the end of the program and the actual 
program time can be measured as the time between two succe- 
ssive EOF outputs. 

2920 SiCaSIAL FROCESSING AFFLICA.TI0NS SOFTWARE 

A package for the development of software for 2920 
applications is available on the MDS. It consists of three 
parts;. 

a) SFAS 20 Compiler 

b) AS 2920 Assembler 

c) SM 2920 Simulator. 

D-9 SPAS 20 COMPILER 

This is a very useful software and some of its uses 
are listed below, 

a) Design of filters^; Digital filters may be designed 
effectively \xsing this software support. It is capable of 
providing frequency response of individual poles both in the 
S and Z planes. Phase plots are possible for the above. 
Frequency response for pole-zero combinations in cascade or 



parallel are also provided. This helps in manipulation of 
the poles/zeroes to derive filters with desired response. 
Macros may be included to obtain pole/zeroes of Butterworth 
and Chebyshev filters on specifying the filter character- 
istics. 

In the present implementation, this package was used 
to study the responses? of the individual complex pole pairs. 
Then the responses; were aeumraed in parallel to obtain the 
Gharacteri sties for the implemented Leruer filters. 

All poles in the s plane can be transformed to the 
Z plane, by the Matched Z or Bilinear- transformations. The 
response of the Z plane singularities- can now be compared 
with that of the S plane and necessary adjustments made. 
During transformation by the Bilinear transform, additional 
zeroes are automatically- evaluated by the compiler., 

In the implementation of the Lemer filters since 
HR filters are needed, the Matched Z transform has been 
used. 

b) Coding of poles/zeroes: The filter coefficients- 

(Figure D,4) are computed and the 2920 instruction code 
is produced by a single code command. The xxser.' must specify 
the nimvber of instructions and the error bounds for 

coding each singularity. The nurttoer of instructions that 
may be allowed for such coding depends on the available 
program length. There are macros which can create the code 
for cascaded poles, avoiding intermediate overflows and 
finally; advising the input scaling required. Zeroes are 
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separately coded and appended appropriately. 

c) A/D conversion: By providing information of the Sigin 

pin to be used, a macro can be xised to generate an A/D 
conversion code which can be saved in a separate file and 
merged with the other instructions subsequently. It is 
easy to follow the use of this compiler through one run of 
the print out in the 2920 Sigml Processor Applications 
Software/Compiler User's Guide [22 j. 

D-IO AS 2920 ASSEMBLER 

The AS 2920 assembler can be called upon to assemble 
the contents of a source file into object code for the 2920. 
The assembler's main features are: 

a) Assemble the 2920 assembly language instructions into 
object code. 

b) In. this process it lists errors such as syntax, 
ille<^l instruction sequences etc. 

Some examples of illegal sequences are: 

1) A LDA EAR, XX instruction immediately following a IN 
or CVT instruction, 

2) ECP instruction is not at a location divisible by 
foTor 

and so on. 

Error lists- are available in the Assembly Language 
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D-11 SM' 2920 SIMULATOR 

The simulator loads / the specified object file for 
execution and is a very important tool for software develop- 
ment. The, Simulator duplicates precisely the worTdLng of 
the 2920, Software Control is provided by the Simulator in 
the following rtanner: 

a) Trace collection - The contents of any of the 40 RAM 
locations and input/autput values can be traced once 
every pass or alv^ays by setting the Qmlifier. 

b) Time for execution of one pass of the program can be 
specified. This automatically sets the instruction 
time and sampling rate. Varying this, it is easy to 
study filter response changes for varying sampling 
rates, 

c) The trace data collected can be viewed either in tabu- 
lar format or graphically by use of the CTaph On command, 

d) All through simulation, a time record is kept for trace 
collection and computation of time dependent input 
functions, which ttey have been defined as inputs, 

e) Under simulator control, ROM locations may be altered 
and the final program saved by use of the SAVE command. 

A typical Simulator Design would follow a sequence 
as below: 

1) Invofe simulator 

2) Load Hex file of program to be simulated 

3) Set the trace qualifier. 

4) Indicate inputs/outputs/RAM locations to be traced 
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5) Specify input function 

6) Check that TPROG and TINST (Read only) are set to 
desired valiies 

1 ,) "Console off" command prevents data from trace buffer 
being displayed and speeds up simulation 

8) Simulate with break points 

9) Call up trace data 

10) Examine ROM/RAM contents and modify any ROM location 

11) Simulate with modified RCM locations 
Save final program for burning the EPROM. 
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TABLE D-1 

Signal Frocessmg Functions of 2920 


FfLTERINO 

•“Complex, polfeii & zerocfs 
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. ».WA,¥EFQRH 0£H£RATI0N | 
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- Amplitude, $r | 

ii:c)duiatf0r^ . J 

I ' muctssm 

j , ■ “Ph^sst Icicked 

i “Atleptlvci’ . 

i 

1 

? 

j 

' , ■ ! 

1 

T 
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! ■ " 

"" ” 
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\ KCfi 
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1 im 

1 Aes 
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XOR XXX.YYY.CNOiki - Enable 
eOP -Enable 


TABLE 0-3 

Output' Mode for SI§out Pins as FuncHons .of. H1 & M2' 


rii 

M2 

SI|out Pins 

Sv 

Sv 
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Sv 

-5v 
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